:root{--bg-primary: #faf8f4;--bg-secondary: #f5f2eb;--bg-card: #ffffff;--text-primary: #2c2825;--text-secondary: #5a534a;--text-muted: #6d665d;--accent: #8b6f4e;--accent-hover: #725839;--accent-light: #c4a882;--border: #e5dfd6;--border-light: #efe9e0;--success: #4a6a4a;--success-light: #e8f0e8;--warning: #8a6b3a;--error: #b85050;--error-light: #f8e8e8;--favorite: #c49040;--focus-ring: rgba(139, 111, 78, .4)}*{margin:0;padding:0;box-sizing:border-box}*:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.skip-link{position:absolute;top:-40px;left:0;background:var(--accent);color:#fff;padding:8px 16px;z-index:10000;transition:top .3s;text-decoration:none;font-weight:500}.skip-link:focus{top:0}.visually-hidden,.sr-announcement{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}body{font-family:Georgia,Times New Roman,serif;background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh}.loading-screen{position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--bg-primary);display:flex;align-items:center;justify-content:center;z-index:9999}.loading-content{text-align:center}.loading-content h1{font-size:2rem;font-weight:400;letter-spacing:.4em;color:var(--text-primary);margin-bottom:2rem}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background-color:var(--bg-primary)}.auth-container{width:100%;max-width:400px;background-color:var(--bg-card);border:1px solid var(--border);border-radius:2px;padding:2rem;box-shadow:0 4px 12px #2c28251a}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-size:1.75rem;font-weight:400;letter-spacing:.4em;color:var(--text-primary);margin-bottom:.5rem}.auth-subtitle{font-size:.9375rem;font-style:italic;color:var(--text-muted)}.auth-definition{font-size:.875rem;color:var(--text-secondary);line-height:1.5;max-width:320px;margin:0 auto}.auth-form{margin-top:1.5rem}.auth-hint{font-size:.8125rem;color:var(--text-muted);text-align:center;margin-top:1rem}.auth-sent{text-align:center}.auth-sent-icon{font-size:3rem;margin-bottom:1rem}.auth-sent h2{font-size:1.25rem;font-weight:500;margin-bottom:.5rem}.auth-completing{text-align:center;padding:2rem}.header{background-color:var(--bg-secondary);padding:2rem 1rem 1.5rem;text-align:center;border-bottom:1px solid var(--border);position:relative;display:flex;justify-content:center;align-items:center}.header-hamburger{position:absolute;right:1rem;top:50%;transform:translateY(-50%)}.header h1{font-size:1.5rem;font-weight:400;letter-spacing:.4em;color:var(--text-primary);margin-bottom:.25rem}.header .subtitle{font-size:.875rem;font-style:italic;color:var(--text-muted);letter-spacing:.15em}.header .header-content{cursor:pointer;display:inline-block;transition:opacity .2s ease}.header .header-content:hover{opacity:.8}.header:after{content:"";position:absolute;bottom:-1px;left:50%;transform:translate(-50%);width:100px;height:1px;background-color:var(--accent-light)}.sticky-header{position:fixed;top:0;left:0;right:0;background-color:var(--bg-secondary);padding:.75rem 1rem;border-bottom:1px solid var(--border);z-index:100;display:none;align-items:center;box-shadow:0 2px 8px #2c282514}.sticky-header.visible{display:flex}.sticky-header .header-left{display:flex;flex-direction:column;flex-shrink:0;cursor:pointer;transition:opacity .2s ease}.sticky-header .header-left:hover{opacity:.8}.sticky-header h1{font-size:1rem;font-weight:400;letter-spacing:.3em;line-height:1.2}.sticky-header .subtitle{font-size:.625rem;font-style:italic;color:var(--text-muted);letter-spacing:.1em}.sticky-header .header-center{flex:1;display:flex;justify-content:center;padding:0 1rem}.sticky-header .header-search{width:100%;max-width:400px;position:relative}.sticky-header .header-search input{width:100%;padding:.5rem .75rem .5rem 2rem;border:1px solid var(--border);border-radius:2px;font-family:inherit;font-size:.875rem;background-color:var(--bg-card)}.sticky-header .header-search input:focus{outline:none;border-color:var(--accent)}.sticky-header .header-search .search-icon{position:absolute;left:.6rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.mobile-search-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem;color:var(--text-secondary)}.hamburger-menu{background:none;border:none;cursor:pointer;padding:.5rem;display:flex;flex-direction:column;gap:4px;flex-shrink:0;margin-left:auto}.hamburger-menu span{display:block;width:20px;height:2px;background-color:var(--text-secondary);transition:all .2s}.hamburger-menu:hover span{background-color:var(--accent)}.mobile-search-bar{display:none;position:fixed;top:52px;left:0;right:0;background-color:var(--bg-secondary);padding:.75rem 1rem;border-bottom:1px solid var(--border);z-index:99}.mobile-search-bar.visible{display:block}.mobile-search-bar input{width:100%;padding:.625rem .75rem;border:1px solid var(--border);border-radius:2px;font-family:inherit;font-size:1rem;background-color:var(--bg-card)}.header-spacer{height:0;transition:height .3s ease}.header-spacer.active{height:52px}.header-spacer.with-search{height:104px}.dropdown-menu{position:fixed;top:52px;right:1rem;background-color:var(--bg-card);border:1px solid var(--border);border-radius:2px;box-shadow:0 4px 12px #2c282526;z-index:101;min-width:200px;display:none}.dropdown-menu.active{display:block}.dropdown-item{padding:.75rem 1rem;cursor:pointer;font-size:.875rem;color:var(--text-secondary);border-bottom:1px solid var(--border-light);transition:all .2s}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background-color:var(--bg-secondary);color:var(--accent)}.dropdown-item.danger{color:var(--error)}.dropdown-item.danger:hover{background-color:var(--error-light)}.container{max-width:1200px;margin:0 auto;padding:1rem}.nav-tabs{display:flex;gap:0;margin-bottom:1rem;border-bottom:1px solid var(--border)}.nav-tab{padding:.75rem 1.25rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);cursor:pointer;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s;background:none;font-family:inherit}.nav-tab:hover{color:var(--accent)}.nav-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.6875rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.375rem}.form-input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:2px;font-family:inherit;font-size:.9375rem;background-color:var(--bg-card);color:var(--text-primary)}.form-input:focus{outline:none;border-color:var(--accent)}.form-input::placeholder{color:var(--text-muted);font-style:italic}.form-hint{font-size:.8125rem;color:var(--text-muted);margin-top:.25rem;font-style:italic}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group-half{margin-bottom:1rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9375rem}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.625rem 1rem;border:1px solid var(--border);border-radius:2px;font-family:inherit;font-size:.75rem;font-weight:400;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:all .2s;background-color:transparent;color:var(--text-secondary);text-decoration:none;white-space:nowrap;min-height:2.25rem}.btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn.loading{position:relative;color:transparent!important;pointer-events:none}.btn.loading:after{content:"";position:absolute;width:14px;height:14px;top:50%;left:50%;margin-left:-7px;margin-top:-7px;border:2px solid var(--border);border-radius:50%;border-top-color:var(--accent);animation:btn-spinner .6s linear infinite}.btn-primary.loading:after{border-color:#ffffff4d;border-top-color:#fff}@keyframes btn-spinner{to{transform:rotate(360deg)}}.btn-primary{background-color:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--accent-hover);border-color:var(--accent-hover);color:#fff}.btn-secondary{background-color:var(--bg-secondary);border-color:var(--border);color:var(--text-secondary)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-primary);border-color:var(--accent);color:var(--accent)}.btn-danger{color:var(--error);border-color:var(--error)}.btn-danger:hover:not(:disabled){border-color:var(--error);background-color:var(--error-light);color:var(--error)}.btn-block{width:100%}.btn-small{padding:.375rem .625rem;font-size:.625rem;min-height:1.75rem}.btn-large{padding:.75rem 1.5rem;font-size:.875rem;min-height:2.75rem}.btn-group{display:flex;flex-wrap:wrap;gap:.5rem}.btn-icon{padding:.5rem;min-width:2.25rem}.btn-icon.btn-small{padding:.375rem;min-width:1.75rem}.controls{background-color:var(--bg-card);border:1px solid var(--border);border-radius:2px;padding:1rem;margin-bottom:1rem;box-shadow:0 1px 3px #2c282514}.search-bar{display:flex;gap:.5rem;margin-bottom:1rem}.search-bar input{flex:1;padding:.75rem 1rem;border:1px solid var(--border);border-radius:2px;font-family:inherit;font-size:.9375rem;background-color:var(--bg-secondary)}.search-bar input:focus{outline:none;border-color:var(--accent)}.filters{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.filter-group{display:flex;flex-direction:column;gap:.25rem}.filter-group label{font-size:.625rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.filter-group select{padding:.5rem 2rem .5rem .75rem;border:1px solid var(--border);border-radius:2px;font-family:inherit;font-size:.875rem;background-color:var(--bg-card);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238a8279' d='M6 8L2 4h8z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center}.filter-group select:focus{outline:none;border-color:var(--accent)}.buttons{display:flex;flex-wrap:wrap;gap:.5rem}.stats-bar{display:flex;justify-content:space-between;align-items:center;padding:0 0 1rem;margin-bottom:1rem;border-bottom:1px solid var(--border-light)}.book-count{font-size:.875rem;color:var(--text-secondary)}.book-count .accent{color:var(--accent);font-weight:500}.favorites-section{margin-bottom:1.5rem}.favorites-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.favorites-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.favorites-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.favorite-slot{aspect-ratio:3/4;background-color:var(--bg-card);border:1px dashed var(--border);border-radius:2px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}.favorite-slot:hover{border-color:var(--accent-light)}.favorite-slot.filled{border-style:solid;border-color:var(--favorite)}.favorite-slot .favorite-spine{position:absolute;left:0;top:0;bottom:0;width:6px}.favorite-slot .favorite-content{padding:.75rem .75rem .75rem 1rem;text-align:center;width:100%}.favorite-slot .favorite-title{font-size:.8125rem;font-weight:500;color:var(--text-primary);line-height:1.3;margin-bottom:.25rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.favorite-slot .favorite-author{font-size:.6875rem;font-style:italic;color:var(--text-muted)}.favorite-slot .remove-favorite{position:absolute;top:.25rem;right:.25rem;width:20px;height:20px;background-color:var(--bg-card);border:1px solid var(--border);border-radius:50%;font-size:.75rem;color:var(--text-muted);cursor:pointer;display:none;align-items:center;justify-content:center}.favorite-slot:hover .remove-favorite{display:flex}.favorite-slot .empty-text{font-size:.6875rem;color:var(--text-muted);font-style:italic}.favorite-star{color:var(--favorite);margin-bottom:.5rem;font-size:1.25rem}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.book-card{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:2px;display:flex;overflow:hidden;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #2c282514;position:relative}.book-card:hover{border-color:var(--accent-light);box-shadow:0 4px 8px #2c28251f}.book-card.is-favorite{border-color:var(--favorite)}.book-spine{width:5px;flex-shrink:0}.book-content{flex:1;padding:1rem 1rem 1rem 1.25rem}.book-title{font-size:1.125rem;font-weight:500;color:var(--text-primary);margin-bottom:.25rem;line-height:1.4}.book-author{font-size:.9375rem;font-style:italic;color:var(--text-secondary);margin-bottom:.5rem;cursor:pointer}.book-author:hover{color:var(--accent)}.book-tags{display:flex;flex-wrap:wrap;gap:.25rem}.tag{padding:.1875rem .5rem;background-color:var(--bg-secondary);border-radius:2px;font-size:.625rem;font-weight:400;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.tag-format{border-left:2px solid var(--accent-light)}.tag-loan{background-color:#9a7b4a1f;color:var(--warning)}.tag-read{background-color:var(--success-light);color:var(--success)}.tag-favorite{background-color:#d4a05026;color:var(--favorite)}.book-notes{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-light);font-size:.875rem;font-style:italic;color:var(--text-muted);line-height:1.4}.favorite-btn{position:absolute;top:.5rem;right:.5rem;background:none;border:none;cursor:pointer;font-size:1rem;color:var(--border);transition:all .2s;padding:.25rem}.favorite-btn:hover,.favorite-btn.active{color:var(--favorite)}.empty-state{text-align:center;padding:3rem;background-color:var(--bg-card);border:1px dashed var(--border);border-radius:2px}.empty-state h2{font-size:1.25rem;font-weight:400;color:var(--text-secondary);margin-bottom:.5rem}.empty-state p{font-size:.9375rem;font-style:italic;color:var(--text-muted);margin-bottom:1rem;line-height:1.5}.lists-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.list-card{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:2px;padding:1.25rem;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #2c282514}.list-card:hover{border-color:var(--accent-light)}.list-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.list-card-title{font-size:1.125rem;font-weight:500;color:var(--text-primary)}.list-card-count{font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background-color:var(--bg-secondary);padding:.25rem .5rem;border-radius:2px}.list-card-description{font-size:.875rem;font-style:italic;color:var(--text-muted);line-height:1.4}.new-list-card{border-style:dashed;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:150px}.new-list-card:hover{border-color:var(--accent)}.new-list-icon{font-size:2rem;color:var(--text-muted);margin-bottom:.5rem}.new-list-text{font-size:.875rem;color:var(--text-muted)}.friends-container{max-width:800px}.friends-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.friends-header h2{font-size:1.5rem;font-weight:400}.section-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:1rem}.friend-requests-section,.pending-requests-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-light)}.friend-card{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:2px;padding:1rem;display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;transition:all .2s}.friend-card:hover{border-color:var(--accent-light)}.friend-info{flex:1}.friend-name{font-size:1rem;font-weight:500;color:var(--text-primary);margin-bottom:.25rem}.friend-email{font-size:.875rem;color:var(--text-muted)}.friend-stats{font-size:.8125rem;color:var(--text-secondary);margin-top:.25rem}.friend-actions{display:flex;gap:.5rem}.friend-search-section{margin-bottom:1rem}.friend-search-results{max-height:200px;overflow-y:auto;border:1px solid var(--border);border-radius:4px;margin-top:.5rem}.friend-search-results:empty{display:none}.friend-search-result{padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid var(--border-light);transition:background-color .15s}.friend-search-result:last-child{border-bottom:none}.friend-search-result:hover{background-color:var(--bg-secondary)}.friend-search-name{font-weight:500;color:var(--text-primary)}.friend-search-library{font-size:.8125rem;color:var(--text-muted);margin-top:.125rem}.friend-search-empty{padding:1rem;text-align:center;color:var(--text-muted);font-style:italic}.friend-divider{text-align:center;margin:1.5rem 0;position:relative}.friend-divider:before{content:"";position:absolute;left:0;right:0;top:50%;height:1px;background-color:var(--border)}.friend-divider span{background-color:var(--bg-card);padding:0 1rem;position:relative;color:var(--text-muted);font-size:.8125rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}@media (max-width: 480px){.form-row{grid-template-columns:1fr}}.modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#2c282566;justify-content:center;align-items:center;z-index:1000;padding:1rem}.modal-overlay.active{display:flex}.modal{background-color:var(--bg-card);border-radius:2px;padding:1.5rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 16px #2c282526}.modal-wide{max-width:650px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.modal-title{font-size:1.25rem;font-weight:400}.modal-hint{font-size:.8125rem;color:var(--text-muted);font-style:italic;margin:.75rem 0 .5rem}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted);padding:.25rem;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}.onboarding-modal{max-width:450px;text-align:center}.onboarding-modal h2{font-size:1.375rem;font-weight:400;margin-bottom:.75rem}.onboarding-text{color:var(--text-secondary);line-height:1.6;margin-bottom:1.5rem}.onboarding-bookplate{margin-bottom:1.5rem}.bookplate-preview{display:inline-block;padding:1.5rem 2.5rem;border:2px solid var(--accent);background-color:var(--bg-secondary);text-align:center}.bookplate-label{display:block;font-size:.75rem;letter-spacing:.3em;color:var(--accent);margin-bottom:.375rem}.bookplate-name{display:block;font-size:1.125rem;font-style:italic;color:var(--text-primary)}.onboarding-modal .form-group{text-align:left;margin-bottom:1.5rem}.onboarding-options{display:flex;flex-direction:column;gap:.75rem;text-align:left}.onboarding-option{display:flex;align-items:center;gap:1rem;padding:1rem;border:1px solid var(--border);border-radius:4px;cursor:pointer;transition:all .2s}.onboarding-option:hover{border-color:var(--accent);background-color:var(--bg-secondary)}.onboarding-option-icon{font-size:1.5rem;flex-shrink:0}.onboarding-option-text{display:flex;flex-direction:column;gap:.125rem}.onboarding-option-text strong{font-size:.9375rem;font-weight:500;color:var(--text-primary)}.onboarding-option-text span{font-size:.8125rem;color:var(--text-muted)}.settings-content{max-height:60vh;overflow-y:auto}.settings-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-light)}.settings-section:last-child{border-bottom:none;margin-bottom:0}.settings-section-title{font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:1rem}.settings-email{font-size:.9375rem;margin-bottom:1rem}.settings-buttons{display:flex;gap:.75rem;flex-wrap:wrap}.settings-buttons .btn{flex:1;min-width:150px}.api-usage-note{font-size:.875rem;color:var(--text-secondary);margin-bottom:1.5rem}.api-usage-table{width:100%;border-collapse:collapse;margin-bottom:1.5rem;font-size:.9375rem}.api-usage-table th,.api-usage-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border)}.api-usage-table th{font-weight:500;color:var(--text-secondary);font-size:.8125rem;text-transform:uppercase;letter-spacing:.05em}.api-usage-table tfoot td{border-top:2px solid var(--border);border-bottom:none;padding-top:1rem}.api-usage-additional{background-color:var(--bg-secondary);padding:1rem;border-radius:4px;margin-bottom:1rem}.api-usage-additional h4{font-size:.875rem;font-weight:500;margin-bottom:.5rem}.api-usage-additional p{font-size:.875rem;margin:.25rem 0}.api-usage-disclaimer{font-size:.8125rem;color:var(--text-muted);margin-top:1rem}.book-picker{max-height:400px;overflow-y:auto;border:1px solid var(--border);border-radius:2px}.book-picker-item{padding:.75rem 1rem;border-bottom:1px solid var(--border-light);cursor:pointer;transition:all .2s}.book-picker-item:last-child{border-bottom:none}.book-picker-item:hover{background-color:var(--bg-secondary)}.book-picker-title{font-size:.9375rem;font-weight:500;color:var(--text-primary)}.book-picker-author{font-size:.8125rem;font-style:italic;color:var(--text-muted)}.scan-container,.audio-input-section,.metrics-container{background-color:var(--bg-card);border:1px solid var(--border);border-radius:2px;padding:1.5rem;margin-bottom:1rem}.scan-header,.metrics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.scan-title,.metrics-title{font-size:1.25rem;font-weight:400}.scan-subtitle{font-size:.875rem;font-style:italic;color:var(--text-muted);margin-bottom:1.5rem}.scan-upload-area{border:2px dashed var(--border);border-radius:2px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .2s;background-color:var(--bg-secondary)}.scan-upload-area:hover{border-color:var(--accent)}.scan-upload-area.dragover{border-color:var(--accent);background-color:#8b6f4e1a}.scan-upload-icon{font-size:3rem;margin-bottom:1rem}.scan-upload-text{font-size:1rem;color:var(--text-secondary);margin-bottom:.5rem}.scan-upload-hint{font-size:.875rem;font-style:italic;color:var(--text-muted)}.scan-preview{max-width:100%;max-height:400px;margin:1rem auto;display:block;border-radius:2px;border:1px solid var(--border)}.scan-model-selection{margin:1.5rem 0}.model-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.75rem;display:block}.model-options{display:flex;flex-wrap:wrap;gap:.5rem}.model-option{padding:.5rem 1rem;border:2px dashed var(--border);border-radius:2px;cursor:pointer;transition:all .2s;background-color:var(--bg-secondary);font-size:.875rem;color:var(--text-muted)}.model-option:hover{border-color:var(--accent);color:var(--text-secondary)}.model-option.selected{background-color:var(--accent);border:2px solid var(--accent);color:#fff}.scan-progress{margin:1rem 0}.scan-progress-bar{height:4px;background-color:var(--border);border-radius:2px;overflow:hidden}.scan-progress-fill{height:100%;background-color:var(--accent);width:0%;transition:width .3s}.scan-progress-text{font-size:.75rem;color:var(--text-muted);margin-top:.5rem;text-align:center;font-family:ui-monospace,monospace;letter-spacing:.5px}.scan-preview-container{position:relative;margin-top:1rem;overflow:hidden;border-radius:4px}.scan-preview-container .scan-preview{display:block;width:100%;height:auto}.scan-line{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--accent),var(--accent-light),var(--accent),transparent);box-shadow:0 0 15px var(--accent),0 0 30px var(--accent-light);opacity:0;transform:translateY(0)}.scan-line.scanning{opacity:1;animation:scanAnimation 2.5s ease-in-out infinite}@keyframes scanAnimation{0%{transform:translateY(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(calc(100% + 300px));opacity:0}}.scan-commentary{margin-top:1rem;min-height:2.5rem;text-align:center;font-style:italic;color:var(--text-secondary);font-size:.9375rem;line-height:1.4;opacity:0;transition:opacity .3s ease}.scan-commentary.visible{opacity:1}.scan-results{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-light)}.scan-results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.scan-results-title{font-size:1rem;font-weight:500}.scan-result-item,.audio-result-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:2px;margin-bottom:.5rem}.scan-result-info{flex:1}.scan-result-title{font-size:.9375rem;font-weight:500;color:var(--text-primary)}.scan-result-author{font-size:.875rem;font-style:italic;color:var(--text-secondary)}.scan-result-confidence{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.scan-result-source{font-size:.625rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background-color:var(--bg-card);padding:.125rem .375rem;border-radius:2px;margin-left:.5rem}.scan-result-actions{display:flex;gap:.5rem}.scan-result-item.verified{border-left:3px solid #4caf50}.scan-result-item.multi-source{background-color:#8b6f4e0d}.scan-result-status{display:flex;align-items:center;justify-content:center;width:2.5rem;margin-right:.75rem;flex-shrink:0}.confidence-score{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border-radius:50%;font-size:.8125rem;font-weight:600;color:#fff;background-color:var(--score-color);box-shadow:0 1px 3px #00000026}.confidence-score.confidence-high{background-color:var(--success)}.confidence-score.confidence-medium{background-color:var(--warning);color:#333}.confidence-score.confidence-low{background-color:var(--error)}.verified-badge{display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;background-color:#4caf50;color:#fff;border-radius:50%;font-size:.75rem;font-weight:700}.unverified-badge{display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;background-color:var(--border);color:var(--text-muted);border-radius:50%;font-size:.75rem;font-weight:700}.scan-result-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.375rem;margin-top:.375rem}.confidence-badge{font-size:.625rem;text-transform:uppercase;letter-spacing:.05em;padding:.125rem .375rem;border-radius:2px}.confidence-badge.confidence-high{background-color:#e8f5e9;color:#2e7d32}.confidence-badge.confidence-medium{background-color:#fff8e1;color:#f9a825}.confidence-badge.confidence-low{background-color:#fce4ec;color:#c62828}.source-badge{font-size:.5625rem;text-transform:uppercase;letter-spacing:.05em;padding:.125rem .375rem;border-radius:2px;background-color:var(--bg-card);color:var(--text-muted);border:1px solid var(--border-light)}.source-badge.source-claude{background-color:#fff3e0;color:#e65100;border-color:#ffcc80}.source-badge.source-openai{background-color:#e3f2fd;color:#1565c0;border-color:#90caf9}.source-badge.source-gemini{background-color:#f3e5f5;color:#7b1fa2;border-color:#ce93d8}.agreement-note{font-size:.625rem;color:var(--text-muted);font-style:italic}.format-badge{font-size:.5625rem;text-transform:uppercase;letter-spacing:.05em;padding:.125rem .375rem;border-radius:2px;background-color:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-light)}.color-badge{font-size:.5625rem;text-transform:capitalize;padding:.125rem .375rem;border-radius:2px;border:1px solid rgba(0,0,0,.1)}.recovered-badge{font-size:.5625rem;padding:.125rem .375rem;border-radius:2px;background-color:var(--success-light);color:var(--success);border:1px solid var(--success)}.corrected-note{color:#ff9800;cursor:help;font-weight:700;margin-left:.25rem}.scan-result-extra{font-size:.6875rem;color:var(--text-muted);margin-top:.25rem}.scan-result-subjects{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.375rem}.subject-tag{display:inline-block;font-size:.625rem;padding:.125rem .375rem;background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:2px;color:var(--text-secondary)}.scan-result-classification{display:flex;gap:.5rem;margin-top:.25rem}.classification-tag{font-size:.625rem;font-family:Courier New,monospace;padding:.125rem .375rem;background-color:var(--accent-light);color:var(--text-primary);border-radius:2px;opacity:.8}#scan-result-summary{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.single-source-toggle{color:var(--primary);cursor:pointer;text-decoration:underline}.single-source-toggle:hover{color:var(--primary-dark)}.count-warning{display:inline-block;font-size:.75rem;padding:.25rem 0}.count-warning.missing-books{color:#f57c00}.count-warning.extra-books{color:#e53935}.count-info{display:inline-block;font-size:.75rem;color:var(--text-muted)}.no-reliable-results{padding:1.5rem;text-align:center;color:var(--text-muted)}.no-reliable-results a{color:var(--primary)}.scan-section{margin-bottom:1.5rem}.scan-section-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-radius:4px;margin-bottom:.5rem}.scan-section-high{background-color:var(--success-light);border:1px solid var(--success)}.scan-section-review{background-color:#fff8e6;border:1px solid var(--warning)}.scan-section-title{font-weight:500;font-size:.9375rem}.scan-section-high .scan-section-title{color:var(--success)}.scan-section-review .scan-section-title{color:var(--warning)}.scan-section-hint{font-size:.75rem;color:var(--text-muted)}.scan-section-items{display:flex;flex-direction:column;gap:.5rem}.scan-section-collapsed .scan-section-items{display:none}.scan-section-collapsed .scan-section-header{cursor:pointer;opacity:.8}.scan-section-collapsed .scan-section-header:hover{opacity:1}.expand-hint{font-size:.6875rem;font-weight:400;color:var(--text-muted);margin-left:.5rem}.source-badge{font-size:.5625rem;text-transform:lowercase;padding:.125rem .375rem;border-radius:2px;background-color:var(--bg-secondary);color:var(--text-muted);border:1px solid var(--border-light)}.edit-scan-info{background-color:var(--bg-secondary);padding:.75rem;border-radius:2px;margin:1rem 0;font-size:.875rem}.edit-scan-info p{margin:.25rem 0}.edit-scan-info .verified-info{color:#4caf50;font-weight:500}.edit-scan-info .unverified-info{color:var(--text-muted);font-style:italic}.candidate-list{display:flex;flex-direction:column;gap:.5rem;max-height:250px;overflow-y:auto;margin-bottom:.75rem}.candidate-option{padding:.75rem;background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:2px;cursor:pointer;transition:all .15s}.candidate-option:hover{border-color:var(--accent);background-color:var(--bg-card)}.candidate-option.high-match{border-left:3px solid var(--success)}.candidate-title{font-weight:500;margin-bottom:.125rem}.candidate-author{font-size:.8125rem;font-style:italic;color:var(--text-secondary)}.candidate-meta{font-size:.6875rem;color:var(--text-muted);margin-top:.25rem;display:flex;gap:.75rem}.candidate-source{text-transform:uppercase;letter-spacing:.05em}.candidate-keep{padding:.5rem .75rem;background-color:var(--bg-primary);border:1px dashed var(--border);border-radius:2px;cursor:pointer;font-size:.8125rem;color:var(--text-secondary)}.candidate-keep:hover{border-color:var(--accent);border-style:solid}.candidate-keep span{color:var(--text-muted)}.audio-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem;background-color:var(--bg-secondary);border:2px solid var(--border);border-radius:2px;cursor:pointer;transition:all .2s;font-family:inherit;font-size:1rem;color:var(--text-secondary)}.audio-btn:hover{border-color:var(--accent);color:var(--accent)}.audio-btn.recording{background-color:var(--error-light);border-color:var(--error);color:var(--error);animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.audio-icon{font-size:1.5rem}.audio-transcript{margin-top:1rem;padding:1rem;background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:2px;font-size:.9375rem;color:var(--text-secondary);min-height:60px}.audio-results{margin-top:1rem}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.metric-card{background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:2px;padding:1rem}.metric-model{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.5rem}.metric-row{display:flex;justify-content:space-between;font-size:.875rem;margin-bottom:.25rem}.metric-label{color:var(--text-secondary)}.metric-value{font-weight:500}.metric-value.good{color:var(--success)}.metric-value.warning{color:var(--warning)}.metric-value.poor{color:var(--error)}.metrics-section{margin-bottom:1.5rem}.metrics-section-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-light)}.metrics-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.metric-card-db{background-color:var(--bg-primary);border-color:var(--accent)}.metric-card-usage{background-color:var(--bg-primary);border-color:var(--success)}.metrics-summary{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background-color:var(--bg-secondary);border-radius:4px;margin-top:.5rem;font-size:.875rem;color:var(--text-secondary)}.metrics-total-cost{color:var(--text-primary)}.metrics-total-cost strong{color:var(--success)}.api-key-notice{background-color:var(--bg-secondary);border:1px solid var(--border);border-left:3px solid var(--warning);padding:1rem;margin-bottom:1rem;font-size:.875rem}.toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%) translateY(100px);background-color:var(--text-primary);color:var(--bg-primary);padding:.75rem 1.5rem;border-radius:2px;font-size:.875rem;opacity:0;transition:all .3s;z-index:1001}.toast.show{transform:translate(-50%) translateY(0);opacity:1}.back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.875rem;text-decoration:none;margin-bottom:1rem;cursor:pointer}.back-link:hover{color:var(--accent)}.scan-results{margin:0 -.5rem;padding:0 .5rem}.scan-section-items{padding:0 .25rem}@media (max-width: 768px){.container{padding:.75rem}.favorites-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.form-row{grid-template-columns:1fr}.sticky-header .header-center{display:none}.mobile-search-toggle{display:flex;margin-left:auto;margin-right:.5rem}.hamburger-menu{margin-left:0}.filters{flex-direction:column}.filter-group,.filter-group select{width:100%}.book-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.lists-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.scan-section-header{flex-direction:column;align-items:flex-start;gap:.25rem;padding:.625rem .875rem}.scan-result-item{flex-direction:column;align-items:flex-start;gap:.75rem;padding:1rem;margin:.375rem 0;border-radius:8px}.scan-result-status{position:absolute;top:.75rem;right:.75rem;margin-right:0}.scan-result-item{position:relative;padding-right:3.5rem}.scan-result-info{width:100%}.scan-result-actions{width:100%;justify-content:flex-start;gap:.75rem;padding-top:.5rem;border-top:1px solid var(--border-light);margin-top:.25rem}.scan-result-actions .btn{flex:1;min-width:0}.modal{max-height:85vh;margin:.5rem}.modal-overlay{padding:.5rem}#edit-scan-modal .modal{max-height:90vh;padding:1rem}#edit-scan-modal .modal-header{margin-bottom:1rem;padding-bottom:.75rem}#edit-scan-modal .modal-title{font-size:1.125rem}#edit-scan-modal .modal-hint{font-size:.75rem;margin:.5rem 0}#edit-scan-modal .form-group{margin-bottom:.875rem}#edit-scan-modal .form-label{font-size:.625rem;margin-bottom:.25rem}#edit-scan-modal .form-input{padding:.625rem;font-size:1rem}#edit-scan-modal .form-row{gap:.75rem}#edit-scan-modal .modal-actions{flex-wrap:wrap;gap:.5rem;padding-top:.75rem;margin-top:1rem}#edit-scan-modal .modal-actions .btn{flex:1;min-width:calc(50% - .25rem);padding:.75rem .5rem}#edit-scan-modal .edit-scan-info{padding:.625rem;font-size:.8125rem}.friend-card{flex-direction:column;align-items:flex-start;gap:.75rem}.friend-actions{width:100%;justify-content:flex-start}.metrics-grid{grid-template-columns:1fr}.settings-buttons{flex-direction:column}.settings-buttons .btn{min-width:unset;width:100%}.book-detail-actions{display:flex;flex-wrap:wrap;gap:.5rem}.book-detail-actions .btn{flex:1;min-width:calc(50% - .25rem)}}@media (max-width: 480px){.header h1{font-size:1.25rem;letter-spacing:.3em}.header{padding:1.5rem .75rem 1rem}.nav-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.nav-tabs::-webkit-scrollbar{display:none}.nav-tab{padding:.5rem .75rem;font-size:.6875rem;flex-shrink:0}.book-grid{grid-template-columns:1fr;gap:.75rem}.lists-grid{grid-template-columns:1fr}.favorites-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.favorite-slot .favorite-title{font-size:.75rem}.favorite-slot .favorite-author{font-size:.625rem}.controls{padding:.75rem}.search-bar{flex-direction:column}.search-bar input{width:100%}.buttons{flex-direction:column}.buttons .btn{width:100%}.scan-upload-area{padding:2rem 1rem}.scan-upload-icon{font-size:2rem}.toast{left:1rem;right:1rem;transform:translateY(100px);text-align:center}.toast.show{transform:translateY(0)}.modal{max-width:100%;max-height:100vh;border-radius:0;margin:0}.modal-overlay{padding:0}.book-detail-actions .btn{min-width:100%}.message-actions{flex-direction:column}.message-actions .btn{width:100%}.borrow-actions{flex-direction:column}.borrow-actions .btn{width:100%}.similar-books-grid{grid-template-columns:1fr}.api-usage-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.scan-section{margin:0 -.75rem 1.5rem;padding:0 .75rem}.scan-section-header{margin:0 -.75rem .5rem;padding:.5rem .75rem;border-radius:0}.scan-section-title{font-size:.8125rem}.scan-section-hint{font-size:.6875rem}.scan-result-item{margin:.5rem 0;padding:.875rem;border-radius:8px;background-color:var(--bg-card);box-shadow:0 1px 3px #00000014}.scan-result-title{font-size:1rem;padding-right:2.5rem}.scan-result-author{font-size:.9375rem}.scan-result-meta{margin-top:.5rem}.scan-result-actions{gap:.5rem}.scan-result-actions .btn{padding:.625rem .875rem;font-size:.6875rem}.confidence-score{width:2rem;height:2rem;font-size:.75rem}#edit-scan-modal .modal{height:100%;display:flex;flex-direction:column}#edit-scan-modal .modal-header{flex-shrink:0}#edit-scan-modal form{flex:1;display:flex;flex-direction:column;overflow-y:auto}#edit-scan-modal .modal-hint{font-size:.6875rem;color:var(--text-muted)}#edit-scan-modal .form-input,#edit-scan-modal .form-input select{font-size:16px;padding:.75rem;border-radius:4px}#edit-scan-modal .form-row{grid-template-columns:1fr;gap:.75rem}#edit-scan-modal .modal-actions{flex-shrink:0;position:sticky;bottom:0;background:var(--bg-card);margin:0 -1rem -1rem;padding:1rem;border-top:1px solid var(--border);gap:.5rem}#edit-scan-modal .modal-actions .btn{flex:1 1 auto;min-width:0;padding:.875rem .5rem;font-size:.6875rem}#edit-scan-modal .modal-actions .btn:nth-child(2){background-color:var(--bg-secondary);border-color:var(--accent);color:var(--accent)}#edit-scan-modal .edit-scan-info{margin:.75rem 0;padding:.5rem .625rem;font-size:.75rem;border-radius:4px}}@media (min-width: 1200px){.container{max-width:1400px}.book-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}.modal-large{max-width:700px;width:95%}.organize-content{padding:1rem}.organize-description{color:var(--text-secondary);margin-bottom:1rem}.organize-presets{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.organize-preset{font-size:.8125rem;padding:.5rem .75rem}.organize-preset:hover{background-color:var(--primary);color:#fff}.organize-results{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-light)}.organize-results h3{font-size:1rem;font-weight:500;margin-bottom:1rem}.organize-category{margin-bottom:1.5rem;padding:1rem;background-color:var(--bg-secondary);border-radius:4px}.organize-category-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.organize-category-name{font-weight:500;font-size:1rem}.organize-category-count{font-size:.75rem;color:var(--text-muted);background-color:var(--bg-primary);padding:.125rem .5rem;border-radius:10px}.organize-book-list{display:flex;flex-wrap:wrap;gap:.5rem}.organize-book-chip{font-size:.75rem;padding:.25rem .5rem;background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:2px}.organize-loading{text-align:center;padding:2rem}.organize-loading p{margin-top:1rem;color:var(--text-muted)}.friends-with-book{margin-top:1.5rem;padding:1rem;background-color:var(--bg-secondary);border-radius:4px}.friends-with-book-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;font-weight:500}.friends-with-book-list{display:flex;flex-wrap:wrap;gap:.5rem}.friend-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:2px;font-size:.8125rem;cursor:pointer;transition:all .15s}.friend-chip:hover{border-color:var(--accent);background-color:var(--bg-card)}.recommend-content{padding:1rem}.recommend-book-info{padding:1rem;background-color:var(--bg-secondary);border-radius:4px;margin-bottom:1rem}.recommend-book-title{font-weight:500;font-size:1rem}.recommend-book-author{font-size:.875rem;color:var(--text-secondary);font-style:italic}.recommend-friends-list{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto}.recommend-friend-option{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:4px;cursor:pointer;transition:all .15s}.recommend-friend-option:hover{border-color:var(--accent)}.recommend-friend-option.has-book{opacity:.6}.recommend-friend-name{font-weight:500}.recommend-friend-status{font-size:.75rem;color:var(--text-muted)}.similar-from-friends{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-light)}.similar-from-friends h3{font-size:1rem;font-weight:500;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.similar-books-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.similar-book-card{padding:.75rem;background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:4px}.similar-book-title{font-weight:500;font-size:.875rem}.similar-book-author{font-size:.8125rem;color:var(--text-secondary);font-style:italic}.similar-book-owner{font-size:.75rem;color:var(--text-muted);margin-top:.5rem}.suggested-friends{margin-top:1rem;padding:1rem;background-color:#8b6f4e0d;border:1px dashed var(--border);border-radius:4px}.suggested-friends h4{font-size:.875rem;font-weight:500;margin-bottom:.5rem;color:var(--accent)}.messages-container,.borrowing-container{max-width:800px;margin:0 auto}.messages-header,.borrowing-header{margin-bottom:1.5rem}.messages-header h2,.borrowing-header h2{font-size:1.5rem;font-weight:400}.messages-tabs,.borrowing-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.messages-tab,.borrowing-tab{padding:.75rem 1.25rem;font-size:.875rem;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}.messages-tab:hover,.borrowing-tab:hover{color:var(--text-primary)}.messages-tab.active,.borrowing-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 .375rem;font-size:.6875rem;background-color:var(--bg-secondary);border-radius:10px;margin-left:.375rem}.messages-tab.active .tab-count,.borrowing-tab.active .tab-count{background-color:var(--primary);color:#fff}.messages-list,.borrowing-list{display:flex;flex-direction:column;gap:.75rem}.message-card{padding:1rem;background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:4px;transition:all .15s}.message-card:hover{border-color:var(--border)}.message-card.unread{border-left:3px solid var(--primary);background-color:#8b6f4e08}.message-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.message-from{font-weight:500}.message-date{font-size:.75rem;color:var(--text-muted)}.message-book{padding:.75rem;background-color:var(--bg-secondary);border-radius:4px;margin-bottom:.75rem}.message-book-title{font-weight:500}.message-book-author{font-size:.875rem;color:var(--text-secondary);font-style:italic}.message-text{font-size:.875rem;color:var(--text-secondary);margin-bottom:.75rem;line-height:1.5}.message-actions{display:flex;gap:.5rem;flex-wrap:wrap}.notification-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.125rem;height:1.125rem;padding:0 .25rem;font-size:.625rem;font-weight:600;background-color:#e53935;color:#fff;border-radius:10px;margin-left:.375rem}.borrow-card{padding:1rem;background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:4px}.borrow-card.pending{border-left:3px solid #ff9800}.borrow-card.active{border-left:3px solid var(--success)}.borrow-card.returned{opacity:.7}.borrow-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.borrow-status{font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;padding:.25rem .5rem;border-radius:2px}.borrow-status.pending{background-color:#fff3e0;color:#e65100}.borrow-status.active{background-color:#e8f5e9;color:#2e7d32}.borrow-status.returned{background-color:var(--bg-secondary);color:var(--text-muted)}.borrow-book-info,.borrow-content .borrow-book-info{padding:.75rem;background-color:var(--bg-secondary);border-radius:4px;margin-bottom:.75rem}.borrow-book-title{font-weight:500}.borrow-book-author{font-size:.875rem;color:var(--text-secondary);font-style:italic}.borrow-person{font-size:.875rem;color:var(--text-secondary);margin-bottom:.75rem}.borrow-date{font-size:.75rem;color:var(--text-muted)}.borrow-actions{display:flex;gap:.5rem;margin-top:.75rem}.borrow-history{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-light)}.borrow-history-title{font-size:.75rem;font-weight:500;color:var(--text-muted);margin-bottom:.5rem}.borrow-history-item{font-size:.75rem;color:var(--text-muted);padding:.25rem 0}.chat-container{display:flex;flex-direction:column;height:400px}.chat-context{padding:.75rem;background-color:var(--bg-secondary);border-radius:4px;margin-bottom:.75rem;font-size:.875rem}.chat-messages{flex:1;overflow-y:auto;padding:.75rem;border:1px solid var(--border-light);border-radius:4px;margin-bottom:.75rem;display:flex;flex-direction:column;gap:.75rem}.chat-message{max-width:80%;padding:.625rem .875rem;border-radius:12px;font-size:.875rem;line-height:1.4}.chat-message.sent{align-self:flex-end;background-color:var(--primary);color:#fff;border-bottom-right-radius:4px}.chat-message.received{align-self:flex-start;background-color:var(--bg-secondary);border-bottom-left-radius:4px}.chat-message-time{font-size:.625rem;opacity:.7;margin-top:.25rem}.chat-input-area{display:flex;gap:.5rem}.chat-input-area textarea{flex:1}.chat-input-area button{align-self:flex-end}.messages-empty,.borrowing-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.messages-empty h3,.borrowing-empty h3{font-size:1.125rem;font-weight:400;margin-bottom:.5rem;color:var(--text-secondary)}.btn-borrow{background-color:#1976d2;color:#fff}.btn-borrow:hover{background-color:#1565c0}.admin-container{max-width:1000px;margin:0 auto}.admin-header{margin-bottom:2rem}.admin-header h2{font-size:1.5rem;font-weight:400;margin-bottom:.5rem}.admin-header p{color:var(--text-muted);font-size:.875rem}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.admin-stat-card{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:2px;padding:1.25rem;text-align:center;box-shadow:0 1px 3px #2c282514}.admin-stat-value{font-size:2rem;font-weight:500;color:var(--accent);line-height:1.2}.admin-stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-top:.5rem}.admin-section{margin-bottom:2rem}.admin-section-title{font-size:.875rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-light)}.admin-users-list{display:flex;flex-direction:column;gap:.75rem}.admin-user-card{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:2px;padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center;transition:all .2s;box-shadow:0 1px 3px #2c282514}.admin-user-card:hover{border-color:var(--accent-light)}.admin-user-info{flex:1;min-width:0}.admin-user-name{font-size:1rem;font-weight:500;color:var(--text-primary);margin-bottom:.25rem;display:flex;align-items:center;gap:.5rem}.admin-user-email{font-size:.875rem;color:var(--text-muted);margin-bottom:.25rem}.admin-user-library{font-size:.8125rem;font-style:italic;color:var(--text-secondary)}.admin-user-stats{display:flex;gap:1rem;margin-right:1.5rem}.admin-user-stat{text-align:center;min-width:60px}.admin-user-stat strong{display:block;font-size:1.125rem;color:var(--accent)}.admin-user-stat span{font-size:.625rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.admin-user-dates{display:flex;flex-direction:column;gap:.25rem;margin-right:1.5rem;min-width:140px}.admin-user-date{font-size:.75rem;color:var(--text-muted)}.admin-user-actions{display:flex;gap:.5rem}.admin-badge{display:inline-block;font-size:.5625rem;text-transform:uppercase;letter-spacing:.05em;padding:.125rem .375rem;background-color:var(--accent);color:#fff;border-radius:2px;font-weight:500}.admin-detail-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-light)}.admin-detail-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.admin-detail-section h3{font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.75rem}.admin-detail-row{display:flex;justify-content:space-between;padding:.5rem 0;font-size:.875rem}.admin-detail-row span:first-child{color:var(--text-muted)}.admin-detail-row span:last-child{color:var(--text-primary);font-weight:500}.admin-books-list{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto}.admin-book-item{padding:.5rem .75rem;background-color:var(--bg-secondary);border-radius:2px;font-size:.875rem}.admin-book-item strong{color:var(--text-primary)}.admin-book-item span{color:var(--text-muted);font-style:italic}.admin-empty{text-align:center;padding:3rem;background-color:var(--bg-secondary);border:1px dashed var(--border);border-radius:2px;color:var(--text-muted)}.admin-loading{text-align:center;padding:3rem;color:var(--text-muted)}@media (max-width: 768px){.admin-stats{grid-template-columns:repeat(2,1fr)}.admin-user-card{flex-direction:column;align-items:flex-start;gap:1rem}.admin-user-stats{margin-right:0;width:100%;justify-content:flex-start}.admin-user-dates{margin-right:0;width:100%}.admin-user-actions{width:100%;justify-content:flex-start}}@media (max-width: 480px){.admin-stats{grid-template-columns:1fr 1fr;gap:.75rem}.admin-stat-card{padding:1rem}.admin-stat-value{font-size:1.5rem}.admin-user-stats{flex-wrap:wrap;gap:.75rem}.admin-user-stat{min-width:50px}.admin-user-actions{flex-direction:column}.admin-user-actions .btn{width:100%}}
