:root{--travertine:#eae3d4;--stone-recess:#ddd3bf;--stone-edge:#c9bda3;--ink:#26221b;--umber:#6e6353;--bronze:#8c6d2f;--bronze-deep:#6f5624;--verdigris:#4f7265;--shadow:2px 4px 10px #26221b47;--serif:Palatino, "Palatino Linotype", "Book Antiqua", Georgia, serif;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;font-family:var(--serif);color:var(--ink);background:var(--travertine);font-size:17px;line-height:1.55}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial;--travertine:#211d17;--stone-recess:#2b261e;--stone-edge:#473e2d;--ink:#e8dfcc;--umber:#a89a82;--bronze:#b08d45;--bronze-deep:#c9a355;--verdigris:#7fa392;--shadow:2px 4px 12px #00000080}}*{box-sizing:border-box}body{background:var(--travertine);min-height:100svh;margin:0}button,input,select,textarea{font-family:var(--serif)}#app{max-width:940px;min-height:100svh;margin:0 auto;padding:0 20px 56px}.masthead{text-align:center;padding:36px 0 0;position:relative}.masthead .rule{border:0;border-top:1px solid var(--ink);max-width:420px;margin:0 auto}.masthead .rule+.rule{border-top-color:var(--bronze);max-width:380px;margin-top:3px}.brand{letter-spacing:.55em;text-indent:.55em;text-transform:uppercase;color:var(--ink);margin:20px 0 6px;font-size:26px;font-weight:400}.tagline{letter-spacing:.28em;text-indent:.28em;text-transform:uppercase;color:var(--bronze);margin:0 0 28px;font-size:11.5px}.utility-row{align-items:center;gap:10px;display:flex;position:absolute;top:14px;right:0}.epigraph{text-align:center;max-width:640px;margin:0 auto;padding:4px 0 10px}.epigraph blockquote{text-wrap:balance;justify-content:center;align-items:center;min-height:3em;margin:0;font-size:26px;font-style:italic;line-height:1.35;display:flex}.epigraph cite{letter-spacing:.24em;text-indent:.24em;text-transform:uppercase;color:var(--bronze);margin-top:12px;font-size:12px;font-style:normal;display:block}.epigraph cite:before{content:"— "}.another{color:var(--umber);letter-spacing:.22em;text-indent:.22em;text-transform:uppercase;cursor:pointer;background:0 0;border:none;border-bottom:1px solid #0000;margin-top:14px;padding:6px 10px;font-size:11px}.another:hover{color:var(--bronze-deep);border-bottom-color:var(--bronze)}.another:focus-visible,.btn:focus-visible,.search-input:focus-visible,.sort-select:focus-visible{outline:2px solid var(--bronze);outline-offset:2px}.epigraph .foot-rule{border:0;border-top:1px solid var(--stone-edge);max-width:200px;margin:22px auto 0}.btn{border:1px solid var(--stone-edge);background:var(--stone-recess);color:var(--ink);cursor:pointer;letter-spacing:.16em;text-indent:.16em;text-transform:uppercase;border-radius:0;padding:11px 18px;font-size:12px;transition:background .15s,border-color .15s}.btn:hover{border-color:var(--bronze)}.btn-primary{background:var(--bronze);border-color:var(--bronze);color:var(--travertine)}.btn-primary:hover{background:var(--bronze-deep);border-color:var(--bronze-deep)}@media (prefers-color-scheme:dark){.btn-primary{color:#211d17}}.btn-ghost{background:0 0}.btn-icon{letter-spacing:0;text-indent:0;justify-content:center;align-items:center;width:38px;height:38px;padding:0;font-size:16px;display:inline-flex}.account-btn{border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;padding:3px;display:inline-flex}.account-btn .avatar{object-fit:cover;border-radius:50%;width:28px;height:28px}.toolbar{align-items:stretch;gap:12px;margin:32px 0 8px;display:flex}.search-input{border:1px solid var(--stone-edge);background:var(--stone-recess);color:var(--ink);border-radius:0;flex:1;padding:11px 16px;font-size:15px}.search-input::placeholder{color:var(--umber);font-style:italic}.sort-select{border:1px solid var(--stone-edge);background:var(--stone-recess);color:var(--ink);letter-spacing:.06em;cursor:pointer;border-radius:0;padding:11px 14px;font-size:13px}.count-line{letter-spacing:.18em;text-indent:.18em;text-transform:uppercase;color:var(--umber);text-align:right;font-variant-numeric:tabular-nums;margin:10px 2px 30px;font-size:12px}.empty-state{text-align:center;color:var(--umber);padding:70px 20px}.empty-state .orn{letter-spacing:.5em;text-indent:.5em;color:var(--bronze);margin-bottom:14px;font-size:15px}.empty-state h2{letter-spacing:.2em;text-indent:.2em;text-transform:uppercase;color:var(--ink);margin:0 0 10px;font-size:17px;font-weight:400}.empty-state p{margin:0;font-style:italic}.genre-section{margin-bottom:44px}.genre-heading{letter-spacing:.26em;text-transform:uppercase;color:var(--ink);align-items:baseline;gap:14px;margin:0 0 20px;font-size:14px;font-weight:400;display:flex}.genre-count{color:var(--bronze);letter-spacing:.2em;white-space:nowrap;font-size:12px}.genre-heading:after{content:"";border-top:1px solid var(--stone-edge);flex:1;transform:translateY(-4px)}.shelf-grid{border-bottom:3px double var(--stone-edge);grid-template-columns:repeat(auto-fill,minmax(128px,1fr));gap:26px 22px;padding-bottom:18px;display:grid}.book-card{cursor:pointer;text-align:left;color:var(--ink);font-size:inherit;background:0 0;border:none;flex-direction:column;gap:2px;padding:0;display:flex}.book-cover{aspect-ratio:2/3;background:var(--stone-recess);box-shadow:inset 3px 0 0 #0000002e, var(--shadow);border-radius:1px;justify-content:center;align-items:center;margin-bottom:8px;transition:transform .15s,box-shadow .15s;display:flex;overflow:hidden}.book-cover img{object-fit:cover;width:100%;height:100%}.book-card:hover .book-cover{transform:translateY(-3px);box-shadow:inset 3px 0 #0000002e,3px 8px 16px #26221b59}.fallback-title{letter-spacing:.08em;text-transform:uppercase;text-align:center;color:var(--umber);padding:12px;font-size:12px}.book-title{text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:14px;line-height:1.3;display:-webkit-box;overflow:hidden}.book-author{color:var(--umber);font-size:12.5px;font-style:italic}.note-badge{letter-spacing:.16em;text-transform:uppercase;color:var(--verdigris);align-items:center;gap:5px;margin-top:4px;font-size:10.5px;display:inline-flex}.note-badge svg{display:block}.colophon{text-align:center;border-top:1px solid var(--stone-edge);letter-spacing:.3em;text-indent:.3em;text-transform:uppercase;color:var(--umber);margin-top:40px;padding-top:24px;font-size:11px}.overlay{z-index:50;background:#14110c99;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}@media (width>=640px){.overlay{align-items:center}}.sheet{background:var(--travertine);border:1px solid var(--stone-edge);border-bottom:none;width:100%;max-width:560px;max-height:92svh;padding:24px;position:relative;overflow-y:auto}@media (width>=640px){.sheet{border-bottom:1px solid var(--stone-edge);max-height:85svh}}.sheet h2{letter-spacing:.22em;text-indent:.22em;text-transform:uppercase;margin:0 0 18px;font-size:16px;font-weight:400}.sheet-close{position:absolute;top:14px;right:14px}.scanner-video-wrap{aspect-ratio:3/4;border:1px solid var(--stone-edge);background:#14110c;max-height:60svh;position:relative;overflow:hidden}.scanner-video-wrap video,.scanner-video-wrap canvas{object-fit:cover;width:100%;height:100%}.scan-frame{pointer-events:none;border:1px solid #eae3d4d9;position:absolute;inset:12%}.scanner-status{color:#eae3d4;text-align:center;background:#14110cbf;padding:8px 12px;font-size:13px;font-style:italic;position:absolute;bottom:10px;left:10px;right:10px}.mode-toggle{border:1px solid var(--stone-edge);gap:0;margin:0 0 16px;display:flex}.mode-toggle button{background:var(--stone-recess);cursor:pointer;letter-spacing:.14em;text-indent:.14em;text-transform:uppercase;color:var(--umber);border:none;flex:1;padding:11px;font-size:11.5px}.mode-toggle button+button{border-left:1px solid var(--stone-edge)}.mode-toggle button.active{background:var(--bronze);color:var(--travertine)}@media (prefers-color-scheme:dark){.mode-toggle button.active{color:#211d17}}.capture-row{gap:10px;margin-top:14px;display:flex}.capture-row .btn{flex:1}.match-list{flex-direction:column;gap:10px;margin-top:14px;display:flex}.match-card{border:1px solid var(--stone-edge);cursor:pointer;text-align:left;background:var(--stone-recess);color:var(--ink);font-size:inherit;align-items:center;gap:12px;padding:10px;display:flex}.match-card:hover{border-color:var(--bronze)}.match-card img{object-fit:cover;background:var(--stone-edge);flex-shrink:0;width:48px;height:72px}.match-card .info{flex:1;min-width:0}.match-card .info .t{font-size:14.5px}.match-card .info .a{color:var(--umber);font-size:12.5px;font-style:italic}.detail-header{gap:16px;margin-bottom:16px;display:flex}.detail-cover{aspect-ratio:2/3;width:100px;box-shadow:inset 3px 0 0 #0000002e, var(--shadow);background:var(--stone-recess);flex-shrink:0;overflow:hidden}.detail-cover img{object-fit:cover;width:100%;height:100%}.detail-cover-btn{background:var(--stone-recess);cursor:pointer;border:1px solid #0000;padding:0;transition:border-color .15s,transform .15s;display:block}.detail-cover-btn:hover{border-color:var(--bronze);transform:translateY(-2px)}.detail-cover-btn:focus-visible{outline:2px solid var(--bronze);outline-offset:2px}.cover-hint{text-align:center;width:100px;color:var(--umber);margin-top:8px;font-size:10px;font-style:italic;line-height:1.4}.detail-info h2{letter-spacing:.04em;text-indent:0;text-transform:none;margin:0 0 4px;font-size:17px;font-weight:600}.detail-info .a{color:var(--umber);margin-bottom:4px;font-size:13.5px;font-style:italic}.detail-actions{gap:8px;margin-top:10px;display:flex}.genre-input{border:1px solid var(--stone-edge);background:var(--stone-recess);color:var(--ink);border-radius:0;width:100%;max-width:220px;margin-top:8px;padding:6px 10px;font-size:13px}.notes-label{letter-spacing:.22em;text-indent:.22em;text-transform:uppercase;color:var(--bronze);margin:22px 0 8px;font-size:12px}.notes-textarea{border:1px solid var(--stone-edge);background:var(--stone-recess);width:100%;min-height:220px;color:var(--ink);resize:vertical;border-radius:0;padding:14px;font-size:15px;line-height:1.6}.save-hint{letter-spacing:.16em;text-transform:uppercase;color:var(--umber);text-align:right;min-height:16px;margin-top:6px;font-size:11px}.spinner{border:2px solid #8c6d2f59;border-top-color:var(--bronze);vertical-align:middle;border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.error-text{color:var(--bronze-deep);margin-top:8px;font-size:13.5px;font-style:italic}.hint-text{color:var(--umber);text-align:center;margin-top:8px;font-size:13.5px;font-style:italic}.manual-form{flex-direction:column;gap:10px;margin-top:12px;display:flex}.manual-form input{border:1px solid var(--stone-edge);background:var(--stone-recess);color:var(--ink);border-radius:0;padding:11px 14px;font-size:15px}.drag-ghost{opacity:.25}.sortable-chosen .book-cover{transform:scale(1.03);box-shadow:inset 3px 0 #0000002e,3px 10px 20px #26221b66}@media (width<=560px){.toolbar{flex-wrap:wrap}.search-input{flex-basis:100%}.sort-select{flex:1}.epigraph blockquote{font-size:21px}.brand{font-size:20px}.shelf-grid{grid-template-columns:repeat(auto-fill,minmax(104px,1fr));gap:20px 14px}}@media (prefers-reduced-motion:reduce){.book-cover,.book-card:hover .book-cover{transition:none;transform:none}.spinner{animation-duration:1.5s}}
