:root{--bg:#f4f1ea;--surface:#ffffff;--surface-alt:#f9f7f2;--border:#d6d0c4;--border-strong:#c9c1af;--text:#382110;--muted:#6d6152;--accent:#409d69;--accent-hover:#37855a;--link:#00635d;--gold:#e9a21b;--shadow:0 1px 3px rgba(56,33,16,0.08);--serif:Georgia,"Times New Roman",serif;--sans:"Helvetica Neue",Helvetica,Arial,ui-sans-serif,system-ui,sans-serif}*{box-sizing:border-box}body{margin:0;font-family:var(--sans);background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}a{color:var(--link);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3{font-family:var(--serif);font-weight:700}.container{max-width:1040px;margin:0 auto;padding:1.5rem}header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.75rem;padding-bottom:1rem;border-bottom:2px solid var(--border-strong)}header h1{color:var(--text);font-size:1.9rem}.btn{display:inline-block;background:var(--accent);color:#fff;border:1px solid var(--accent-hover);border-radius:4px;padding:.55rem 1rem;font-family:var(--sans);font-size:.9rem;font-weight:700;cursor:pointer}.btn:hover{background:var(--accent-hover);text-decoration:none}.btn-secondary{background:linear-gradient(#fbfaf7,#efe9dc);border:1px solid var(--border-strong);color:var(--text)}.btn-secondary:hover{background:linear-gradient(#f4f1ea,#e7e0cf)}.card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:1.25rem;box-shadow:var(--shadow)}.muted{color:var(--muted)}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));grid-gap:1.5rem 1.25rem;gap:1.5rem 1.25rem}.book-card{background:transparent;position:relative}.cover-wrap{position:relative;border-radius:4px;overflow:hidden;box-shadow:0 2px 6px rgba(56,33,16,.18);background:var(--border)}.book-card img{width:100%;aspect-ratio:2/3;object-fit:cover;display:block}.cover-fallback{width:100%;aspect-ratio:2/3;background:linear-gradient(135deg,#e9e3d5,#d8d0bd)}.book-card h3{font-size:.95rem;margin:.6rem 0 .15rem;line-height:1.3;color:var(--text)}.book-card .author{margin:0;font-size:.8rem;color:var(--muted)}.rating{display:flex;align-items:center;gap:.35rem;margin:.35rem 0 0;font-size:.8rem}.stars{color:var(--gold);letter-spacing:-1px}.book-meta,.rating-num{color:var(--muted)}.book-meta{font-size:.72rem;margin:.2rem 0 0}.book-award{font-size:.72rem;color:#9a6d00;margin:.3rem 0 0;cursor:help}.genre-tags{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.4rem}.genre-tag{font-size:.66rem;color:var(--muted);background:var(--surface-alt);border:1px solid var(--border);border-radius:3px;padding:.1rem .4rem}.review-badge{position:absolute;top:.4rem;right:.4rem;font-size:.6rem;text-transform:uppercase;letter-spacing:.04em;color:#fff;background:rgba(56,33,16,.75);border-radius:3px;padding:.12rem .35rem}.filter-bar{display:flex;align-items:center;gap:.75rem;margin:0 0 1.5rem;flex-wrap:wrap}.filter-count{margin-left:auto;color:var(--muted);font-size:.85rem}.dropdown{position:relative}.dropdown-btn{display:inline-flex;align-items:center;gap:.4rem;background:linear-gradient(#fbfaf7,#efe9dc);border:1px solid var(--border-strong);border-radius:4px;padding:.5rem .85rem;font-family:var(--sans);font-size:.88rem;font-weight:600;color:var(--text);cursor:pointer}.dropdown-btn:hover{background:linear-gradient(#f4f1ea,#e7e0cf)}.dropdown-btn.open{border-color:var(--accent)}.dropdown-btn .caret{font-size:.7rem;color:var(--muted)}.dropdown-badge{background:var(--accent);color:#fff;border-radius:999px;padding:.05rem .45rem;font-size:.72rem;font-weight:700}.dropdown-panel{position:absolute;top:calc(100% + 4px);left:0;z-index:20;min-width:240px;background:var(--surface);border:1px solid var(--border-strong);border-radius:6px;box-shadow:0 6px 20px rgba(56,33,16,.18);padding:.35rem}.dropdown-scroll{max-height:320px;overflow-y:auto}.dropdown-item{display:flex;align-items:center;gap:.5rem;width:100%;background:none;border:none;text-align:left;padding:.45rem .5rem;border-radius:4px;font-family:var(--sans);font-size:.86rem;color:var(--text);cursor:pointer}.dropdown-item:hover{background:var(--surface-alt)}.dropdown-item.checked{color:var(--accent);font-weight:600}.dropdown-item .check{width:1rem;color:var(--accent);font-weight:700}.dropdown-item-label{flex:1 1}.dropdown-item-count{color:var(--muted);font-size:.75rem}.dropdown-clear{width:100%;background:none;border:none;border-bottom:1px solid var(--border);text-align:left;padding:.45rem .5rem;margin-bottom:.25rem;color:var(--link);font-size:.82rem;cursor:pointer}.status-banner{padding:.75rem 1rem;border-radius:6px;background:var(--surface);border:1px solid var(--border);margin-bottom:1.5rem}.scanning-banner{display:flex;align-items:center;gap:.5rem;padding:.65rem .9rem;border-radius:6px;background:#eaf5ee;border:1px solid #b9dcc7;color:#2f6f49;font-size:.85rem;margin-bottom:1.25rem}.pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 1.4s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.3;transform:scale(.9)}50%{opacity:1;transform:scale(1.15)}}.review-section{margin-top:2rem;padding-top:1.5rem;border-top:1px dashed var(--border-strong)}.pick-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem}.pick-actions .btn{flex:1 1;min-width:140px;text-align:center}.scan-preview{width:100%;max-height:340px;object-fit:contain;border-radius:6px;margin-top:1rem;background:var(--surface-alt);border:1px solid var(--border)}.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));grid-gap:.6rem;gap:.6rem;margin-top:1rem}.preview-item{position:relative;aspect-ratio:3/4;border-radius:6px;overflow:hidden;background:var(--surface-alt);border:1px solid var(--border)}.preview-item img{width:100%;height:100%;object-fit:cover;display:block}.preview-remove{position:absolute;top:4px;right:4px;width:22px;height:22px;padding:0;border:none;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;font-size:.75rem;line-height:22px;text-align:center;cursor:pointer}.preview-remove:hover{background:rgba(0,0,0,.8)}input[type=file],input[type=password],input[type=text]{font-family:var(--sans);color:var(--text);background:var(--surface);border:1px solid var(--border-strong);border-radius:4px}input[type=password]:focus,input[type=text]:focus{outline:none;border-color:var(--accent)}