*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f0f0f;color:#e8e8e8;overscroll-behavior:none}.shell{display:flex;flex-direction:column;min-height:100dvh;max-width:480px;margin:0 auto;background:#1a1a1a;position:relative}.header{display:flex;align-items:center;gap:10px;padding:14px 16px;background:#1a1a1a;border-bottom:1px solid #2e2e2e;flex-shrink:0;z-index:10}.btn-back{background:none;border:none;color:#e8e8e8;font-size:22px;line-height:1;cursor:pointer;padding:2px 6px 2px 0;opacity:.8}.btn-back:hover{opacity:1}.header-title{font-size:17px;font-weight:600;letter-spacing:.2px;flex:1}.content{flex:1;display:flex;flex-direction:column}.upload-page{padding:24px 20px 16px;gap:24px;overflow-y:auto}.hero{text-align:center;padding:8px 0 4px}.hero-icon{font-size:52px;margin-bottom:12px}.hero-title{font-size:22px;font-weight:700;margin-bottom:8px}.hero-sub{font-size:14px;color:#888;line-height:1.5}.drop-zone{border:2px dashed #3a3a3a;border-radius:16px;padding:28px 20px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;background:#141414}.drop-zone:hover,.drop-zone.drag-over{border-color:#5b8dee;background:#1a2340}.drop-icon{font-size:36px;margin-bottom:10px}.drop-text{font-size:14px;color:#aaa;line-height:1.6}.drop-text strong{color:#e8e8e8}.upload-btns{display:flex;flex-direction:column;gap:10px}.btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px 18px;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;line-height:1}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-primary{background:#5b8dee;color:#fff}.btn-secondary{background:#2e2e2e;color:#e8e8e8}.btn-retry{background:#2e4a2e;color:#7dda7d}.btn-soon{background:#2a2a2a;color:#666;cursor:not-allowed}.btn-icon{font-size:18px}.soon-badge{font-size:10px;background:#3a3a2a;color:#aaa86a;padding:2px 6px;border-radius:8px;font-weight:700;letter-spacing:.5px}.btn-history{display:flex;align-items:center;justify-content:center;gap:8px;background:none;border:1px solid #2e2e2e;border-radius:12px;color:#aaa;font-size:14px;font-weight:500;padding:11px 16px;cursor:pointer;transition:border-color .15s,color .15s}.btn-history:hover{border-color:#5b8dee;color:#e8e8e8}.hist-count-badge{background:#5b8dee;color:#fff;font-size:11px;font-weight:700;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}.image-area{position:relative;width:100%;background:#000}.preview-img{width:100%;height:auto;display:block}.box-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.pin-marker polygon{fill:#5b8dee8c;stroke:#fff;stroke-width:1.5px;vector-effect:non-scaling-stroke;transition:fill .15s}.pin-marker circle{fill:#fff;transition:fill .15s}.pin-marker.active polygon{fill:#e53e3e;stroke:#fff}.pin-marker.active circle{fill:#e53e3e}.spine-highlight{fill:#5b8dee1a;stroke:#5b8dee8c;stroke-width:1.5px;vector-effect:non-scaling-stroke;transition:fill .15s,stroke .15s}.spine-highlight.active{fill:#e53e3e38;stroke:#e53e3e;stroke-width:2px}.box-poly{fill:#5b8dee1a;stroke:#5b8dee99;stroke-width:1.5px;vector-effect:non-scaling-stroke;cursor:pointer;pointer-events:all}.box-poly.active{fill:#5b8dee40;stroke:#5b8dee}.img-badge{position:absolute;top:8px;right:8px;background:#000000a6;color:#e8e8e8;font-size:12px;font-weight:600;padding:3px 9px;border-radius:12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.img-hint{position:absolute;bottom:8px;left:50%;transform:translate(-50%);background:#000000a6;color:#ccc;font-size:12px;padding:4px 12px;border-radius:12px;white-space:nowrap;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.scan-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:#0000008c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.scan-text{font-size:14px;font-weight:600;color:#e8e8e8}.spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.15);border-top-color:#5b8dee;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.tap-hint{text-align:center;font-size:12px;color:#666;padding:6px 0 2px;flex-shrink:0}.book-list{padding:6px 0 8px}.book-item{display:flex;align-items:center;gap:12px;padding:11px 16px;cursor:pointer;border-bottom:1px solid #222;transition:background .12s}.book-item:hover{background:#222}.book-item.selected{background:#1a2340}.book-num{font-size:12px;color:#555;min-width:18px;text-align:right;flex-shrink:0;align-self:flex-start;padding-top:2px}.book-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.book-title{font-size:14px;line-height:1.4;color:#e0e0e0;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.book-actions{display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0}.book-pin{font-size:14px}.amazon-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;background:#1a1a1a;transition:background .15s;flex-shrink:0}.amazon-btn:hover{background:#2e2e2e}.rare-badge{font-size:10px;font-weight:700;background:#4a3000;color:#f5c842;padding:2px 6px;border-radius:8px;white-space:nowrap;flex-shrink:0}.book-price-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.price-tag{font-size:11px;font-weight:600;background:#1e3a1e;color:#7dda7d;padding:2px 7px;border-radius:8px;white-space:nowrap}.price-tag.used{background:#2a2a1e;color:#c8c87d}.rare-note{font-size:11px;color:#888;font-style:italic;line-height:1.4}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;gap:8px;text-align:center;color:#666}.empty-icon{font-size:40px;margin-bottom:4px}.empty-title{font-size:16px;font-weight:600;color:#aaa}.empty-sub{font-size:13px;line-height:1.5}.footer{position:sticky;bottom:0;border-top:1px solid #2e2e2e;padding:12px 16px;background:#1a1a1a;z-index:10}.footer-row{display:flex;gap:10px}.hist-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid #222;cursor:pointer;transition:background .12s}.hist-item:hover{background:#222}.hist-thumb{width:52px;height:52px;object-fit:cover;border-radius:8px;background:#111;flex-shrink:0}.hist-info{flex:1;min-width:0}.hist-time{font-size:13px;font-weight:600;color:#e0e0e0;margin-bottom:3px}.hist-count{font-size:12px;color:#888}.hist-status{font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px;flex-shrink:0}.hist-status.done{background:#1e3a1e;color:#7dda7d}.hist-status.failed{background:#3a1e1e;color:#da7d7d}.hist-arrow{font-size:20px;color:#444;flex-shrink:0}.hist-item-deleting{opacity:.4;pointer-events:none}.hist-delete-btn{background:none;border:none;font-size:16px;cursor:pointer;padding:4px 6px;border-radius:6px;color:#666;flex-shrink:0;transition:color .15s,background .15s}.hist-delete-btn:hover{color:#da7d7d;background:#2a1e1e}.hist-saved-count{font-size:11px;color:#7ddaaa;font-weight:600}.hist-save-btn{background:none;border:none;cursor:pointer;font-size:16px;padding:6px 8px;border-radius:6px;color:#7ddaaa;transition:background .15s,color .15s;flex-shrink:0}.hist-save-btn:disabled{opacity:.5;cursor:default}.hist-save-btn:not(:disabled):hover{color:#aed;background:#1e2a22}.btn-save{background:#1e3a2a;color:#7ddaaa}.saved-badge{display:inline-flex;align-items:center;background:#1e3a2a;color:#7ddaaa;font-size:10px;font-weight:700;padding:2px 6px;border-radius:8px;flex-shrink:0}.hist-confirm{display:flex;gap:6px;flex-shrink:0}.hist-confirm-yes,.hist-confirm-no{border:none;border-radius:8px;font-size:12px;font-weight:600;padding:5px 10px;cursor:pointer}.hist-confirm-yes{background:#5a1e1e;color:#da7d7d}.hist-confirm-yes:hover{background:#7a2424}.hist-confirm-no{background:#2e2e2e;color:#aaa}.hist-confirm-no:hover{background:#3a3a3a}.hist-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:48px 24px;color:#666;font-size:14px}.hist-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:56px 24px;gap:8px;text-align:center}.hist-empty-icon{font-size:44px;margin-bottom:4px}.hist-empty-title{font-size:16px;font-weight:600;color:#aaa}.hist-empty-sub{font-size:13px;color:#666;line-height:1.5}.toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%) translateY(12px);background:#333;color:#e8e8e8;font-size:13px;font-weight:500;padding:10px 18px;border-radius:20px;opacity:0;transition:opacity .25s,transform .25s;pointer-events:none;white-space:nowrap;max-width:calc(100% - 40px);text-align:center;z-index:100}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.login-page{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}.login-box{width:100%;max-width:320px;display:flex;flex-direction:column;align-items:center;gap:16px}.login-icon{font-size:48px}.login-title{font-size:20px;font-weight:700;color:#e8e8e8}.login-form{width:100%;display:flex;flex-direction:column;gap:10px}.login-input{width:100%;padding:12px 14px;background:#141414;border:1px solid #2e2e2e;border-radius:10px;color:#e8e8e8;font-size:15px;outline:none;transition:border-color .15s}.login-input:focus{border-color:#5b8dee}.login-error{font-size:13px;color:#da7d7d;text-align:center;padding:4px 0}.books-filters{flex-shrink:0;display:flex;flex-direction:column;gap:8px;padding:10px 16px;border-bottom:1px solid #2e2e2e;background:#141414}.books-search{width:100%;box-sizing:border-box;background:#1e1e1e;border:1px solid #333;border-radius:10px;padding:8px 12px;color:#e8e8e8;font-size:14px;outline:none}.books-search:focus{border-color:#5b8dee}.books-search::placeholder{color:#555}.books-filter-row{display:flex;gap:6px;align-items:center}.filter-btn{flex-shrink:0;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:20px;color:#888;font-size:12px;font-weight:600;padding:5px 12px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.filter-btn:hover{background:#333;color:#aaa}.filter-btn.active{background:#1a2e50;border-color:#5b8dee;color:#5b8dee}.filter-select{margin-left:auto;flex-shrink:0;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;color:#aaa;font-size:12px;padding:5px 8px;cursor:pointer;outline:none}.filter-select:focus{border-color:#5b8dee}.books-count{font-size:11px;color:#555;padding:0 2px}.book-row{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-bottom:1px solid #222;transition:background .12s}.book-row:hover{background:#1c1c1c}.book-row-deleting{opacity:.4;pointer-events:none}.book-row-main{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.book-row-title{font-size:14px;font-weight:500;color:#e0e0e0;line-height:1.4;display:flex;flex-wrap:wrap;align-items:center;gap:6px}.book-row-prices{display:flex;flex-wrap:wrap;gap:4px}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#333;border-radius:2px}
