.canvas-container[data-v-e755c504]{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-e755c504]{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-d7ae6b15]{position:fixed;top:0;right:0;width:320px;height:100%;background:var(--color-surface);transform:translate(100%);transition:transform var(--duration-slow) var(--ease-out-quart);z-index:100;display:flex;flex-direction:column;box-shadow:-4px 0 20px #0000004d}@media(max-width:768px){.settings-panel[data-v-d7ae6b15]{width:100%;max-width:320px}}@media(max-width:480px){.settings-panel[data-v-d7ae6b15]{max-width:100%}}.settings-panel.open[data-v-d7ae6b15]{transform:translate(0)}.panel-header[data-v-d7ae6b15]{display:flex;justify-content:space-between;align-items:center;padding:12px;border-bottom:1px solid rgba(0,0,0,.1)}.panel-title[data-v-d7ae6b15]{font-weight:600;font-size:var(--font-size-lg);color:var(--color-text);margin:0}.close-btn[data-v-d7ae6b15]{font-size:1.5rem;width:var(--control-height);height:var(--control-height)}.panel-content[data-v-d7ae6b15]{flex:1;overflow-y:auto;padding:12px;-webkit-overflow-scrolling:touch}.settings-section[data-v-d7ae6b15]{margin-bottom:12px}.section-title[data-v-d7ae6b15]{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-d7ae6b15]{margin-bottom:8px}.setting-label[data-v-d7ae6b15]{display:block;font-size:var(--font-size-sm);color:var(--color-text);margin-bottom:4px}.setting-hint[data-v-d7ae6b15]{display:block;font-size:.75rem;color:var(--color-text-muted);margin-top:4px}@media(max-width:768px){.setting-group[data-v-d7ae6b15]{margin-bottom:12px}.setting-label[data-v-d7ae6b15]{font-size:13px;margin-bottom:8px}.setting-hint[data-v-d7ae6b15]{font-size:11px}}.dual-slider[data-v-d7ae6b15]{display:flex;flex-direction:column;gap:8px}input[type=range][data-v-d7ae6b15]{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-d7ae6b15]::-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 var(--duration-fast) ease;box-shadow:0 1px 3px #0000004d}@media(hover:hover)and (pointer:fine){input[type=range][data-v-d7ae6b15]::-webkit-slider-thumb:hover{transform:scale(1.1)}}input[type=range][data-v-d7ae6b15]::-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-d7ae6b15]::-moz-range-track{background:var(--slider-track-bg);border-radius:var(--radius-full);height:8px}@media(max-width:768px){input[type=range][data-v-d7ae6b15]{height:10px}input[type=range][data-v-d7ae6b15]::-webkit-slider-thumb{width:22px;height:22px}input[type=range][data-v-d7ae6b15]::-moz-range-thumb{width:22px;height:22px}input[type=range][data-v-d7ae6b15]::-moz-range-track{height:10px}}.setting-select[data-v-d7ae6b15]{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-d7ae6b15]:focus-visible{outline:none;border-color:var(--color-accent)}.setting-select option[data-v-d7ae6b15]{background:var(--color-surface);color:var(--color-text)}.setting-select optgroup[data-v-d7ae6b15]{color:var(--color-text-muted);font-weight:600}.reset-btn[data-v-d7ae6b15]{width:100%;height:auto;padding:12px;border-radius:var(--radius-sm);margin-top:12px}.toggle-label[data-v-d7ae6b15]{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-checkbox[data-v-d7ae6b15]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-accent)}.modal-backdrop[data-v-a2d11b63]{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-a2d11b63]{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-a2d11b63]{display:flex;align-items:center;gap:12px;padding:12px}.search-input-wrapper[data-v-a2d11b63]{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-a2d11b63]{color:var(--color-text-muted);flex-shrink:0}.search-input[data-v-a2d11b63]{flex:1;border:none;background:transparent;padding:10px 0;font-size:14px;color:var(--color-text);outline:none}.search-input[data-v-a2d11b63]::placeholder{color:var(--color-text-muted)}.clear-btn[data-v-a2d11b63]{display:flex;align-items:center;justify-content:center;padding:4px;color:var(--color-text-muted);border-radius:var(--radius-md);transition:color var(--duration-fast) ease,background var(--duration-fast) ease}@media(hover:hover)and (pointer:fine){.clear-btn[data-v-a2d11b63]:hover{color:var(--color-text);background:#0000001a}}.close-btn[data-v-a2d11b63]{display:none;flex-shrink:0;width:var(--control-height);height:var(--control-height)}.modal-content[data-v-a2d11b63]{flex:1;overflow-y:auto;padding:12px}.section-header[data-v-a2d11b63]{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-muted)}.book-list[data-v-a2d11b63]{display:flex;flex-direction:column}.book-item[data-v-a2d11b63]{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.is-focused[data-v-a2d11b63]{background:var(--btn-secondary-bg-hover);outline:none}@media(hover:hover)and (pointer:fine){.book-item[data-v-a2d11b63]:hover{background:var(--btn-secondary-bg-hover)}}.book-item[data-v-a2d11b63]:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.book-info[data-v-a2d11b63]{flex:1;min-width:0;display:flex;flex-direction:column}.book-title[data-v-a2d11b63]{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-a2d11b63]{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-meta[data-v-a2d11b63]{font-size:11px;color:var(--color-text-muted)}.action-btn[data-v-a2d11b63]{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);flex-shrink:0}.add-btn[data-v-a2d11b63]{color:var(--color-accent)}.add-btn.already-added[data-v-a2d11b63],.remove-btn[data-v-a2d11b63]{color:var(--color-text-muted)}.empty-state[data-v-a2d11b63]{text-align:center;padding:32px 16px;color:var(--color-text-muted);font-size:14px}.modal-enter-active[data-v-a2d11b63],.modal-leave-active[data-v-a2d11b63]{transition:opacity var(--duration-slow) var(--ease-out-quad)}.modal-enter-active .modal-container[data-v-a2d11b63]{transition:transform var(--duration-slow) var(--ease-out-quart),opacity var(--duration-slow) var(--ease-out-quad)}.modal-leave-active .modal-container[data-v-a2d11b63]{transition:transform var(--duration-normal) var(--ease-in-out-quad),opacity var(--duration-normal) var(--ease-out-quad)}.modal-enter-from[data-v-a2d11b63],.modal-leave-to[data-v-a2d11b63]{opacity:0}.modal-enter-from .modal-container[data-v-a2d11b63]{transform:translateY(-32px);opacity:0}.modal-leave-to .modal-container[data-v-a2d11b63]{transform:translateY(-16px);opacity:0}@media(max-width:768px){.modal-backdrop[data-v-a2d11b63]{padding:5vh 16px}.modal-container[data-v-a2d11b63]{max-height:80vh}.close-btn[data-v-a2d11b63]{display:flex}}@media(max-width:480px){.modal-backdrop[data-v-a2d11b63]{padding:0}.modal-container[data-v-a2d11b63]{max-width:100%;max-height:100%;border-radius:0}}.shelf-view[data-v-97e2c768]{height:100%;display:flex;flex-direction:column;padding:24px;gap:24px}.header[data-v-97e2c768]{display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.controls-row[data-v-97e2c768]{display:flex;gap:12px;justify-content:center;align-items:center;flex-wrap:wrap}.control-group[data-v-97e2c768]{display:flex;flex-direction:column;gap:4px}.control-label[data-v-97e2c768]{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-muted)}.title[data-v-97e2c768]{font-family:var(--font-display);font-size:1.75rem;font-weight:500;letter-spacing:.02em;color:var(--color-accent)}.main[data-v-97e2c768]{flex:1;min-height:0;display:flex;flex-direction:column}.controls[data-v-97e2c768]{width:100%;display:flex;flex-direction:column;gap:8px}.status[data-v-97e2c768]{font-size:var(--font-size-sm);color:var(--color-text-muted);padding:0 8px}@media(max-width:768px){.shelf-view[data-v-97e2c768]{padding:12px;gap:12px}.header[data-v-97e2c768]{flex-direction:column;align-items:stretch;gap:12px}.controls-row[data-v-97e2c768]{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-97e2c768]::-webkit-scrollbar{height:4px}.controls-row[data-v-97e2c768]::-webkit-scrollbar-thumb{background:var(--color-surface);border-radius:2px}.status[data-v-97e2c768]{font-size:.85rem}}@font-face{font-family:Cas Olgans;src:url(../fonts/CasOlgans-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Komika Axis;src:url(../fonts/KomikaAxis.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Orbit Gate;src:url(../fonts/OrbitGate-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:PP Fraktion Sans;src:url(../fonts/PPFraktionSans-Bold.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:PP Fraktion Sans;src:url(../fonts/PPFraktionSans-Black.woff2) format("woff2");font-weight:900;font-style:normal;font-display:swap}:root{--color-background: #DAD9DB;--color-surface: #fff;--color-text: #000;--color-text-muted: #555;--color-accent: #444;--color-accent-hover: #4A4EB5;--ease-out-quad: cubic-bezier(.25, .46, .45, .94);--ease-out-cubic: cubic-bezier(.215, .61, .355, 1);--ease-out-quart: cubic-bezier(.165, .84, .44, 1);--ease-out-quint: cubic-bezier(.23, 1, .32, 1);--ease-in-out-quad: cubic-bezier(.455, .03, .515, .955);--ease-in-out-cubic: cubic-bezier(.645, .045, .355, 1);--duration-fast: .15s;--duration-normal: .2s;--duration-slow: .3s;--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}}
