@import "https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&family=DM+Sans:wght@300;400;500&display=swap";
.browse-wrap{font-family:DM Sans,sans-serif}.browse-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1.75rem;display:flex}.browse-title{color:#ffffffe6;margin:0 0 .25rem;font-family:Playfair Display,serif;font-size:1.75rem;font-weight:700}.browse-sub{color:#ffffff4d;margin:0;font-size:.82rem}.browse-stats{flex-shrink:0;gap:1.5rem;display:flex}.bstat{text-align:right}.bstat-num{color:#d4a352;font-family:Playfair Display,serif;font-size:1.6rem;font-weight:700;line-height:1;display:block}.bstat-lbl{text-transform:uppercase;letter-spacing:.1em;color:#ffffff38;font-size:.65rem}.browse-wallet-notice{color:#eab308bf;background:#eab3080d;border:1px solid #eab3082e;border-left:3px solid #eab30873;border-radius:2px;margin-bottom:1.5rem;padding:.8rem 1.15rem;font-size:.82rem}.browse-controls{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:2rem;display:flex}.browse-search-wrap{flex:1;min-width:200px;position:relative}.browse-search-icon{pointer-events:none;position:absolute;top:50%;left:.85rem;transform:translateY(-50%)}.browse-search-input{color:#ffffffd9;box-sizing:border-box;background:#ffffff0a;border:1px solid #ffffff14;border-radius:2px;outline:none;width:100%;padding:.65rem 1rem .65rem 2.4rem;font-family:DM Sans,sans-serif;font-size:.85rem;transition:background .18s,border-color .18s,box-shadow .18s}.browse-search-input::placeholder{color:#ffffff2e}.browse-search-input:focus{background:#ffffff0f;border-color:#d4a35266;box-shadow:0 0 0 3px #d4a35212}.browse-filters{background:#ffffff08;border:1px solid #ffffff12;border-radius:2px;gap:.3rem;padding:.22rem;display:flex}.browse-filter-btn{color:#ffffff4d;letter-spacing:.03em;cursor:pointer;background:0 0;border:none;border-radius:2px;padding:.38rem .85rem;font-family:DM Sans,sans-serif;font-size:.75rem;transition:color .15s,background .15s}.browse-filter-btn:hover{color:#ffffffa6}.browse-filter-btn.active{color:#d4a352;background:#d4a3521a;border:1px solid #d4a35233}.books-grid,.books-skeleton-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem;display:grid}.book-skeleton{background:#ffffff06;border:1px solid #ffffff0d;border-radius:4px;animation:1.6s ease-in-out infinite skshimmer;overflow:hidden}.skel-cover{background:#ffffff0a;height:200px}.skel-body{flex-direction:column;gap:.75rem;padding:1.25rem;display:flex}.skel-line{background:#ffffff0d;border-radius:2px;height:11px}.skel-line.w80{width:80%}.skel-line.w55{width:55%}.skel-line.w70{width:70%}@keyframes skshimmer{0%,to{opacity:1}50%{opacity:.5}}.books-empty{text-align:center;border:1px dashed #ffffff12;border-radius:4px;flex-direction:column;grid-column:1/-1;justify-content:center;align-items:center;gap:.85rem;padding:5rem 2rem;display:flex}.books-empty-icon{background:#ffffff08;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;display:flex}.books-empty-title{color:#ffffff73;margin:0;font-family:Playfair Display,serif;font-size:1.05rem}.books-empty-sub{color:#fff3;margin:0;font-size:.78rem}
.book-card{background:#ffffff08;border:1px solid #ffffff12;border-radius:4px;flex-direction:column;transition:background .25s,border-color .25s,transform .25s,box-shadow .25s;display:flex;overflow:hidden}.book-card:hover{background:#ffffff0d;border-color:#d4a35240;transform:translateY(-3px);box-shadow:0 16px 40px #0006,0 0 0 1px #d4a35214}.book-cover{background:linear-gradient(135deg,#111120,#18182e);flex-shrink:0;width:100%;height:200px;position:relative;overflow:hidden}.book-cover img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.book-card:hover .book-cover img{transform:scale(1.05)}.book-cover-placeholder{background:#d4a35208;flex-direction:column;justify-content:center;align-items:center;gap:.6rem;width:100%;height:100%;display:flex}.book-cover-placeholder span{text-transform:uppercase;letter-spacing:.1em;color:#d4a35240;font-size:.65rem}.book-avail-badge{letter-spacing:.1em;text-transform:uppercase;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:2px;padding:.22rem .6rem;font-size:.65rem;font-weight:500;position:absolute;top:.7rem;right:.7rem}.book-avail-badge.available{color:#4ade80;background:#4ade801a;border:1px solid #4ade804d}.book-avail-badge.unavailable{color:#f87171;background:#ef444417;border:1px solid #ef444447}.book-body{flex-direction:column;flex:1;gap:.9rem;padding:1.2rem;font-family:DM Sans,sans-serif;display:flex}.book-body-top{flex:1}.book-card-title{color:#ffffffe6;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 .3rem;font-family:Playfair Display,serif;font-size:1rem;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.book-card-author{color:#ffffff59;margin:0;font-family:Playfair Display,serif;font-size:.8rem;font-style:italic}.book-card-meta{border-top:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding-top:.8rem;display:flex}.book-meta-deposit-label{text-transform:uppercase;letter-spacing:.1em;color:#ffffff38;margin-bottom:.18rem;font-size:.62rem;display:block}.book-meta-deposit-value{color:#d4a352;font-size:.88rem;font-weight:500}.book-meta-borrows{color:#ffffff40;align-items:center;gap:.3rem;font-size:.72rem;display:flex}.book-borrow-btn{letter-spacing:.04em;cursor:pointer;border:none;border-radius:2px;justify-content:center;align-items:center;gap:.45rem;width:100%;padding:.65rem 1rem;font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:500;transition:transform .18s,box-shadow .18s,opacity .18s;display:flex}.book-borrow-btn.can-borrow{color:#080810;background:linear-gradient(135deg,#d4a352,#c8903a)}.book-borrow-btn.can-borrow:hover{transform:translateY(-1px);box-shadow:0 6px 20px #d4a3524d}.book-borrow-btn.can-borrow:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}.book-borrow-btn.on-loan{color:#fff3;cursor:not-allowed;background:#ffffff0a;border:1px solid #ffffff0f}.book-owner-actions{gap:.4rem;display:flex}.book-action-btn{cursor:pointer;border-radius:2px;flex:1;justify-content:center;align-items:center;gap:.3rem;padding:.45rem .6rem;font-family:DM Sans,sans-serif;font-size:.72rem;font-weight:500;transition:all .15s;display:flex}.book-action-btn.edit{color:#d4a352;background:#d4a35214;border:1px solid #d4a35233}.book-action-btn.edit:hover{background:#d4a35226;border-color:#d4a35266}.book-action-btn.delete{color:#f87171;background:#ef44440f;border:1px solid #ef444433}.book-action-btn.delete:hover{background:#ef44441f;border-color:#ef444466}.book-action-btn.save{color:#4ade80;background:#4ade8014;border:1px solid #4ade8040}.book-action-btn.save:hover{background:#4ade8026}.book-action-btn.cancel{color:#ffffff59;background:#ffffff0a;border:1px solid #ffffff14}.book-action-btn.cancel:hover{background:#ffffff12}.book-action-btn:disabled{opacity:.5;cursor:not-allowed}.book-edit-input{color:#ffffffd9;box-sizing:border-box;background:#ffffff0d;border:1px solid #d4a35240;border-radius:2px;outline:none;width:100%;padding:.45rem .65rem;font-family:DM Sans,sans-serif;font-size:.8rem;transition:border-color .15s,box-shadow .15s}.book-edit-input:focus{border-color:#d4a35280;box-shadow:0 0 0 3px #d4a35212}.book-edit-inputs{flex-direction:column;gap:.4rem;margin-bottom:.5rem;display:flex}.book-edit-img-preview{border-radius:2px;height:80px;position:relative;overflow:hidden}.book-edit-img-preview img{object-fit:cover;width:100%;height:100%}.book-edit-img-remove{color:#fff;cursor:pointer;background:#000000a6;border:none;border-radius:2px;align-items:center;gap:3px;padding:2px 6px;font-size:.68rem;display:flex;position:absolute;top:4px;right:4px}.book-edit-upload-label{cursor:pointer;color:#d4a352b3;border:1px dashed #d4a3524d;border-radius:2px;justify-content:center;align-items:center;gap:.4rem;padding:.45rem;font-size:.75rem;transition:all .15s;display:flex}.book-edit-upload-label:hover{color:#d4a352;background:#d4a3520d;border-color:#d4a35299}@keyframes spin{to{transform:rotate(360deg)}}.spin{border:2px solid #4ade80;border-top-color:#0000;border-radius:50%;width:10px;height:10px;animation:.6s linear infinite spin;display:inline-block}
