*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#111;color:#fff;min-height:100vh;min-height:100dvh;width:100vw}.home-view{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;padding:24px 16px;padding-top:max(24px,env(safe-area-inset-top));padding-bottom:max(24px,env(safe-area-inset-bottom))}.home-header{text-align:center;padding:16px 0 24px}.home-title{font-size:24px;font-weight:700;letter-spacing:-.5px}.home-subtitle{font-size:14px;color:#ffffff80;margin-top:4px}.ocr-status{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:12px;font-size:13px;color:#fff6}.ocr-status[hidden]{display:none}.home-actions{display:flex;gap:12px;margin-bottom:24px}.btn-action{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:12px;padding:14px 16px;font-size:15px;font-weight:600;cursor:pointer;min-height:52px;transition:background .2s,opacity .2s}.btn-action:disabled{opacity:.4;pointer-events:none}.btn-primary{background:#fff;color:#000}.btn-primary:active{background:#ddd}.btn-secondary{background:#ffffff1f;color:#fff}.btn-secondary:active{background:#fff3}.home-processing{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px;margin-bottom:16px;background:#ffffff0f;border-radius:12px;font-size:14px;color:#ffffffb3}.home-processing[hidden]{display:none}.home-book-section{flex:1;display:flex;flex-direction:column;min-height:0}.home-book-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.home-book-header>span{font-size:14px;font-weight:500}.scan-view{position:fixed;top:0;left:0;width:100%;height:100%;background:#000;z-index:50}.scan-view[hidden]{display:none}#camera{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}#capture{display:none}.status-overlay{position:absolute;top:0;left:0;right:0;background:#0009;padding:8px 16px;padding-top:max(8px,env(safe-area-inset-top));z-index:10;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.status-row{display:flex;align-items:center;gap:12px;font-size:14px}.btn-back{background:none;border:none;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;margin-left:-8px}.btn-back:active{opacity:.6}.status-row #scan-count{flex:1}.scan-active{color:#4caf50}.scan-paused{color:#ff9800}.last-text{font-size:12px;color:#fff9;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:16px}.scan-controls{position:absolute;bottom:0;left:0;right:0;background:#000000b3;padding:16px;padding-bottom:max(16px,env(safe-area-inset-bottom));z-index:10;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;gap:16px}.scan-controls-row{display:flex;justify-content:space-between;align-items:center;width:100%}.auto-scan-toggle{display:flex;align-items:center;gap:10px}.auto-scan-toggle label{font-size:14px;color:#fffc;-webkit-user-select:none;user-select:none}.toggle-switch{width:52px;height:32px;border-radius:16px;background:#fff3;border:none;cursor:pointer;position:relative;transition:background .2s;padding:0;min-width:52px;min-height:32px}.toggle-switch.toggle-on{background:#4caf50}.toggle-knob{display:block;width:26px;height:26px;border-radius:50%;background:#fff;position:absolute;top:3px;left:3px;transition:transform .2s}.toggle-switch.toggle-on .toggle-knob{transform:translate(20px)}.btn-scan-now{background:none;border:none;cursor:pointer;padding:0;min-width:72px;min-height:72px;display:flex;align-items:center;justify-content:center}.btn-scan-now[hidden]{display:none}.scan-now-ring{width:68px;height:68px;border-radius:50%;border:3px solid rgba(255,255,255,.8);display:flex;align-items:center;justify-content:center;transition:border-color .2s}.btn-scan-now:active .scan-now-ring{border-color:#fff}.scan-now-inner{width:56px;height:56px;border-radius:50%;background:#ffffffe6;transition:background .15s}.btn-scan-now:active .scan-now-inner{background:#fff9}.spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;margin:0 auto;animation:spin .8s linear infinite}.spinner-sm{width:16px;height:16px;border-width:2px;margin:0}@keyframes spin{to{transform:rotate(360deg)}}.control-buttons{display:flex;gap:12px}.control-buttons button{background:#ffffff26;border:none;border-radius:8px;padding:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;min-width:44px;min-height:44px}.control-buttons button:active{background:#ffffff4d}.control-buttons button:disabled{opacity:.3;pointer-events:none}.book-list{overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1;min-height:0}.book-card{display:flex;align-items:flex-start;gap:12px;background:#ffffff14;border-radius:8px;padding:10px;margin-bottom:8px}.book-card img{width:48px;height:64px;object-fit:cover;border-radius:4px;flex-shrink:0;background:#ffffff0d}.book-info{flex:1;min-width:0}.book-title{font-size:14px;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-authors{font-size:12px;color:#ffffffb3;margin-top:2px}.book-isbn{font-size:12px;color:#fff6;margin-top:2px}.drag-handle{display:flex;align-items:center;justify-content:center;flex-shrink:0;min-width:24px;min-height:44px;color:#ffffff4d;cursor:grab;touch-action:none}.drag-handle:active{cursor:grabbing;color:#fff9}.book-card.dragging{opacity:.4}.book-card.drag-over{border-top:2px solid #4caf50}.btn-remove{background:none;border:none;color:#fff6;cursor:pointer;padding:8px;font-size:18px;line-height:1;flex-shrink:0;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.btn-remove:active{color:#ff5252}.book-popup{position:fixed;top:0;left:0;width:100%;height:100%;z-index:90;display:flex;align-items:flex-end;justify-content:center}.book-popup[hidden]{display:none}.book-popup-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:#00000080}.book-popup-sheet{position:relative;width:100%;max-height:70vh;background:#1a1a1a;border-radius:16px 16px 0 0;display:flex;flex-direction:column;overflow:hidden;padding-bottom:max(8px,env(safe-area-inset-bottom))}.book-popup-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.book-popup-title{font-size:16px;font-weight:600}.btn-popup-dismiss{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;color:#fff9}.btn-popup-dismiss:active{color:#fff}.book-popup-list{overflow-y:auto;-webkit-overflow-scrolling:touch;padding:8px 16px;flex:1;min-height:0}.candidate-card{display:flex;align-items:flex-start;gap:12px;background:#ffffff14;border-radius:8px;padding:10px;margin-bottom:8px}.candidate-card img{width:48px;height:64px;object-fit:cover;border-radius:4px;flex-shrink:0;background:#ffffff0d}.candidate-info{flex:1;min-width:0}.confidence-badge{display:inline-block;font-size:11px;font-weight:600;padding:2px 6px;border-radius:4px;margin-top:4px}.confidence-high{color:#4caf50;background:#4caf5026}.confidence-mid{color:#ff9800;background:#ff980026}.confidence-low{color:#f44336;background:#f4433626}.btn-add-book{background:#4caf50;color:#fff;border:none;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;flex-shrink:0;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;transition:background .2s}.btn-add-book:active{background:#388e3c}#error-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}#error-overlay[hidden]{display:none}.error-content{text-align:center;padding:24px}.error-content p{margin-bottom:16px;font-size:16px}#btn-retry{background:#fff;color:#000;border:none;border-radius:8px;padding:10px 24px;font-size:16px;cursor:pointer}.candidate-search{flex:1;min-width:0;margin:0 12px;padding:8px 12px;border:1px solid rgba(255,255,255,.15);border-radius:8px;background:#ffffff14;color:#fff;font-size:16px;font-family:inherit;outline:none;transition:border-color .2s}.candidate-search::placeholder{color:#ffffff4d}.candidate-search:focus{border-color:#fff6}.language-selector{flex-shrink:0;width:100%}.scan-controls .lang-grid{display:flex;flex-direction:row;overflow-x:auto;scrollbar-width:none;gap:6px}.scan-controls .lang-grid::-webkit-scrollbar{display:none}.scan-controls .lang-btn{flex-shrink:0;min-height:44px;padding:6px 8px;min-width:52px}.lang-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.lang-grid-expanded{margin-top:8px;grid-template-columns:repeat(4,1fr)}.lang-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;border:2px solid transparent;border-radius:8px;background:#ffffff14;color:#ffffffb3;cursor:pointer;transition:background .2s,border-color .2s;min-height:52px}.lang-btn:active{background:#ffffff26}.lang-btn:disabled{opacity:.4;pointer-events:none}.lang-btn.lang-active{border-color:#4caf50;background:#4caf5026;color:#fff}.lang-flag{font-size:20px;line-height:1}.lang-label{font-size:10px;text-align:center;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.lang-more .lang-flag{font-size:16px;color:#ffffff80}.lang-loading{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:8px;font-size:13px;color:#fff6}.empty-state{text-align:center;padding:48px 24px;color:#fff6;font-size:14px;line-height:1.6}:focus-visible{outline:2px solid #4fc3f7;outline-offset:2px}.book-link{color:inherit;text-decoration:underline;text-decoration-color:#ffffff4d;text-underline-offset:2px}.book-link:active{text-decoration-color:#fff9}.toast{position:fixed;bottom:calc(max(16px,env(safe-area-inset-bottom)) + 140px);left:50%;transform:translate(-50%) translateY(8px);background:#323232f2;color:#fff;padding:10px 20px;border-radius:8px;font-size:14px;z-index:200;opacity:0;transition:opacity .3s,transform .3s;pointer-events:none;max-width:calc(100vw - 32px);text-align:center}.toast-visible{opacity:1;transform:translate(-50%) translateY(0)}@media(prefers-reduced-motion:reduce){.spinner{animation:none;border-top-color:#fffc;border-right-color:#ffffff80}.toast,.toggle-knob,.toggle-switch,.scan-now-ring,.scan-now-inner,.btn-action,.btn-add-book,.lang-btn,.candidate-search{transition:none}}
