*{box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;color:#333;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}.lending-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.lending-dialog{background:#fff;border-radius:8px;width:90%;max-width:500px;box-shadow:0 4px 6px #0000001a}.lending-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.lending-dialog-header h3{margin:0;font-size:1.25rem;color:#333}.close-button{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.close-button:hover{background-color:#f0f0f0}.lending-dialog-content{padding:20px}.book-info{margin-bottom:20px;padding:15px;background-color:#f8f8f8;border-radius:4px}.book-info h4{margin:0 0 8px;font-size:1.1rem;color:#333}.book-author{margin:0 0 4px;color:#666;font-size:.9rem}.book-isbn{margin:0;color:#888;font-size:.85rem}.lending-form{margin-top:20px}.lending-form label{display:block;margin-bottom:8px;font-weight:500;color:#333}.lending-form input{width:100%;padding:10px 12px;font-size:1rem;border:1px solid #ddd;border-radius:4px;transition:border-color .2s}.lending-form input:focus{outline:none;border-color:#007bff}.lending-form input:disabled{background-color:#f5f5f5;cursor:not-allowed}.return-info{margin-top:20px;padding:15px;background-color:#f0f8ff;border-radius:4px;border:1px solid #b8daff}.return-info p{margin:0 0 8px;color:#333}.return-info p:last-child{margin-bottom:0}.error-message{margin:15px 0;padding:10px 15px;background-color:#fee;border:1px solid #fcc;border-radius:4px;color:#c00;font-size:.9rem}.lending-dialog-actions{display:flex;justify-content:flex-end;gap:10px;padding:20px;border-top:1px solid #e0e0e0}.cancel-button,.lend-button,.return-button{padding:8px 20px;font-size:1rem;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.cancel-button{background-color:#f0f0f0;color:#333}.cancel-button:hover:not(:disabled){background-color:#e0e0e0}.lend-button{background-color:#007bff;color:#fff}.lend-button:hover:not(:disabled){background-color:#0056b3}.return-button{background-color:#28a745;color:#fff}.return-button:hover:not(:disabled){background-color:#218838}.cancel-button:disabled,.lend-button:disabled,.return-button:disabled{opacity:.6;cursor:not-allowed}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;padding:20px}.book-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;transition:transform .2s,box-shadow .2s,opacity .2s;cursor:pointer;position:relative}.book-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.book-card:focus{outline:2px solid #007bff;outline-offset:2px}.book-card.borrowed{opacity:.95}.book-card.borrowed .book-cover{filter:grayscale(20%)}.book-cover{width:100%;height:280px;object-fit:cover}.book-cover-placeholder{width:100%;height:280px;background:#f0f0f0;display:flex;align-items:center;justify-content:center;color:#999;font-size:14px}.book-info{padding:15px}.book-title{font-size:16px;font-weight:700;margin:0 0 8px;color:#333;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-author,.book-publisher{font-size:14px;color:#666;margin:4px 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-isbn{font-size:12px;color:#999;margin:8px 0 0}.book-status-container{display:flex;align-items:center;gap:8px;margin-top:12px}.book-status{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.status-available{background:#e8f5e9;color:#2e7d32}.status-borrowed{background:#fff3e0;color:#f57c00}.status-icon{font-size:16px}.empty-state{text-align:center;padding:60px 20px;color:#666}.isbn-input-form{margin:20px 0}.input-group{display:flex;gap:10px;max-width:500px;margin:0 auto}.isbn-input{flex:1;padding:12px;border:2px solid #ddd;border-radius:6px;font-size:16px;transition:border-color .2s}.isbn-input:focus{outline:none;border-color:#4caf50}.isbn-input:disabled{background:#f5f5f5;cursor:not-allowed}.submit-button{padding:12px 24px;background:#4caf50;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:700;cursor:pointer;transition:background-color .2s}.submit-button:hover:not(:disabled){background:#45a049}.submit-button:disabled{background:#ccc;cursor:not-allowed}.bulk-toggle-button{padding:10px 20px;background:#2196f3;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;transition:background-color .2s}.bulk-toggle-button:hover{background:#1976d2}.bulk-isbn-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.bulk-isbn-content{background:#fff;padding:30px;border-radius:8px;width:90%;max-width:500px;box-shadow:0 4px 20px #00000026}.bulk-isbn-content h3{margin:0 0 20px;color:#333}.bulk-isbn-textarea{width:100%;padding:12px;border:2px solid #ddd;border-radius:6px;font-size:14px;font-family:monospace;resize:vertical;transition:border-color .2s}.bulk-isbn-textarea:focus{outline:none;border-color:#2196f3}.bulk-isbn-textarea:disabled{background:#f5f5f5;cursor:not-allowed}.bulk-isbn-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.cancel-button{padding:10px 20px;background:#f5f5f5;color:#666;border:none;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;transition:background-color .2s}.cancel-button:hover:not(:disabled){background:#e0e0e0}.cancel-button:disabled{cursor:not-allowed}.barcode-scanner-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000}.barcode-scanner-content{background:#fff;border-radius:8px;width:90%;max-width:600px;max-height:90vh;overflow:hidden;box-shadow:0 4px 20px #0000004d}.scanner-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee}.scanner-header h3{margin:0;color:#333}.close-button{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.close-button:hover{background:#f0f0f0}.scanner-viewport{position:relative;width:100%;height:400px;background:#000;overflow:hidden}.scanner-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.scanner-frame{width:280px;height:140px;border:3px solid #4CAF50;border-radius:8px;position:relative}.scanner-frame:before,.scanner-frame:after{content:"";position:absolute;width:30px;height:30px;border:3px solid #4CAF50}.scanner-frame:before{top:-3px;left:-3px;border-right:none;border-bottom:none}.scanner-frame:after{bottom:-3px;right:-3px;border-left:none;border-top:none}.scanner-instruction{text-align:center;padding:20px;color:#666;font-size:14px;margin:0}.scanner-error{padding:40px 20px;text-align:center}.scanner-error p{color:#d32f2f;font-size:16px;margin:0 0 20px}.error-close-button{padding:10px 20px;background:#f5f5f5;color:#666;border:none;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;transition:background-color .2s}.error-close-button:hover{background:#e0e0e0}.lending-scanner-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:1000}.lending-scanner-content{background:#fff;border-radius:8px;width:90%;max-width:600px;max-height:90vh;overflow:auto}.scanner-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.scanner-header h3{margin:0;font-size:1.25rem;color:#333}.scanner-viewport{position:relative;width:100%;aspect-ratio:4/3;background:#000;overflow:hidden}.scanner-video{width:100%;height:100%;object-fit:cover}.scanner-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;justify-content:center;align-items:center;pointer-events:none}.scanner-frame{width:80%;max-width:400px;aspect-ratio:3/1;border:3px solid #00ff00;border-radius:8px;box-shadow:0 0 0 10000px #0000004d}.scanner-instruction{text-align:center;padding:15px 20px 5px;font-size:1rem;color:#333;margin:0}.scanner-hint{text-align:center;padding:0 20px 20px;font-size:.85rem;color:#666;margin:0}.scanner-error{padding:20px;text-align:center}.scanner-error p{margin:0 0 15px;color:#c00;font-size:1rem}.error-close-button{padding:8px 20px;font-size:1rem;background-color:#f0f0f0;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.error-close-button:hover{background-color:#e0e0e0}.dashboard{width:100%}.dashboard-header{margin-bottom:2rem}.dashboard-header h2{margin:0 0 .5rem;font-size:1.875rem;font-weight:700;color:#1e293b}.dashboard-subtitle{margin:0;color:#64748b;font-size:1rem}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;color:#64748b}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;display:flex;align-items:center;gap:1rem;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-card__icon{font-size:2.5rem;flex-shrink:0}.stat-card__content{flex:1;min-width:0}.stat-card__title{margin:0 0 .25rem;font-size:.875rem;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.stat-card__value{font-size:2rem;font-weight:700;color:#1e293b;line-height:1;margin-bottom:.25rem}.stat-card__trend{font-size:.75rem;font-weight:500;color:#6b7280}.stat-card--blue{border-left:4px solid #3b82f6}.stat-card--green{border-left:4px solid #10b981}.stat-card--yellow{border-left:4px solid #f59e0b}.stat-card--red{border-left:4px solid #ef4444}.stat-card--red .stat-card__trend{color:#ef4444;font-weight:600}.stat-card--gray{border-left:4px solid #9ca3af}.stat-card--purple{border-left:4px solid #8b5cf6}.dashboard-section{background:#fff;padding:1.5rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;margin-bottom:1.5rem}.dashboard-section h3{margin:0 0 1rem;font-size:1.125rem;font-weight:600;color:#1e293b}.overdue-list{display:flex;flex-direction:column;gap:.75rem}.overdue-item{display:flex;justify-content:space-between;align-items:flex-start;padding:.75rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;gap:1rem}.overdue-book{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.overdue-book strong{color:#991b1b;font-weight:600}.overdue-borrower{color:#7f1d1d;font-size:.875rem}.overdue-date{color:#7f1d1d;font-size:.875rem;font-weight:500;flex-shrink:0}.overdue-more{text-align:center;color:#6b7280;font-style:italic;padding:.5rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.activity-summary{display:flex;flex-direction:column;gap:.75rem}.activity-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f8fafc;border-radius:.5rem;border:1px solid #e2e8f0}.activity-label{color:#475569;font-weight:500}.activity-value{color:#1e293b;font-weight:700;font-size:1.125rem}.quick-actions{display:flex;flex-direction:column;gap:.75rem}.action-button{padding:.75rem 1rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s;border:none;text-align:left;display:flex;align-items:center;gap:.5rem}.action-button--primary{background:#3b82f6;color:#fff}.action-button--primary:hover:not(:disabled){background:#2563eb}.action-button--secondary{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.action-button--secondary:hover{background:#e2e8f0}.dashboard-empty{margin-top:2rem}.empty-state{text-align:center;padding:3rem 2rem;background:#fff;border-radius:.75rem;border:2px dashed #d1d5db}.empty-state p{margin:0;color:#6b7280}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr;gap:1rem}.stat-card{padding:1rem}.stat-card__value{font-size:1.75rem}.dashboard-grid{grid-template-columns:1fr}.overdue-item{flex-direction:column;align-items:flex-start;gap:.5rem}.overdue-date{align-self:flex-end}.activity-item{flex-direction:column;align-items:flex-start;gap:.25rem}}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.refresh-button{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s;font-size:.875rem}.dashboard-alert{background:#fef2f2;border:1px solid #fecaca;border-radius:.75rem;padding:1.5rem;margin-bottom:2rem}.dashboard-alert h3{margin:0 0 1rem;color:#991b1b;font-size:1.125rem;font-weight:600}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-bottom:2rem}.chart-card{background:#fff;padding:1.5rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0}.chart-card--wide{grid-column:1 / -1}.chart-card h3{margin:0 0 1rem;font-size:1.125rem;font-weight:600;color:#1e293b}.utilization-chart{padding:1rem 0}.utilization-bar{position:relative;height:2rem;background:#f3f4f6;border-radius:1rem;overflow:hidden;margin-bottom:1rem}.utilization-fill{position:absolute;top:0;height:100%;transition:all .3s ease}.utilization-borrowed{background:#f59e0b;left:0}.utilization-available{background:#10b981}.utilization-labels{display:flex;gap:1rem;font-size:.875rem;font-weight:500}.utilization-label{display:flex;align-items:center;gap:.25rem}.recent-books{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.recent-book-item{display:flex;gap:.75rem;padding:1rem;background:#f8fafc;border-radius:.5rem;border:1px solid #e2e8f0;transition:all .2s}.recent-book-item:hover{background:#f1f5f9;border-color:#cbd5e1}.recent-book-item .book-cover{width:40px;height:60px;flex-shrink:0;border-radius:.25rem;overflow:hidden}.recent-book-item .book-cover img{width:100%;height:100%;object-fit:cover}.recent-book-item .no-cover{width:100%;height:100%;background:#e5e7eb;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:#9ca3af}.recent-book-item .book-info{flex:1;min-width:0}.recent-book-item .book-title{display:block;font-weight:600;color:#1e293b;font-size:.875rem;line-height:1.3;margin-bottom:.25rem;word-break:break-word}.recent-book-item .book-author{color:#6b7280;font-size:.75rem;margin-bottom:.25rem}.recent-book-item .book-date{color:#9ca3af;font-size:.75rem}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:1rem 1.5rem;margin-bottom:1.5rem;border-radius:.5rem;display:flex;justify-content:space-between;align-items:center}.error-message button{background:none;border:none;color:#991b1b;cursor:pointer;padding:.25rem .5rem;border-radius:.25rem;font-weight:500}@media (max-width: 1024px){.charts-grid{grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.chart-card--wide{grid-column:1 / -1}}@media (max-width: 768px){.dashboard-header{flex-direction:column;gap:1rem;align-items:stretch}.charts-grid{grid-template-columns:1fr;gap:1rem}.chart-card{padding:1rem}.recent-books{grid-template-columns:1fr}.recent-book-item{padding:.75rem}.utilization-labels{flex-direction:column;gap:.5rem}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.stat-card{flex-direction:column;text-align:center;gap:.75rem}.stat-card__icon{font-size:2rem}.stat-card__value{font-size:1.5rem}.chart-card{padding:.75rem}.recent-book-item{flex-direction:column;align-items:center;text-align:center}.recent-book-item .book-cover{width:60px;height:90px}}.bookshelf-books-modal{background:#fff;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a;width:90%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;border-bottom:1px solid #e2e8f0}.header-content h3{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:.5rem}.book-count{margin:0;color:#64748b;font-size:.875rem}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:.375rem;color:#6b7280;transition:all .2s}.close-button:hover{background:#f3f4f6}.modal-actions{padding:1rem 1.5rem;border-bottom:1px solid #e2e8f0}.action-button{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.action-button:hover:not(:disabled){background:#2563eb}.action-button:disabled{opacity:.6;cursor:not-allowed}.bulk-actions{display:flex;gap:.75rem;align-items:center;margin-top:1rem;padding:1rem;background:#f8fafc;border-radius:.5rem}.action-select,.bookshelf-select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;background:#fff;cursor:pointer;transition:all .2s}.action-select:focus,.bookshelf-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.apply-button{background:#10b981;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.apply-button:hover:not(:disabled){background:#059669}.apply-button:disabled{opacity:.6;cursor:not-allowed}.books-container{flex:1;overflow-y:auto;padding:1.5rem}.books-table th{background:#f8fafc;padding:.75rem;text-align:left;font-weight:600;color:#374151;font-size:.875rem;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:10}.books-table td{padding:.75rem;border-bottom:1px solid #f1f5f9;vertical-align:top}.book-info{max-width:400px}.status-select{padding:.375rem .5rem;border:1px solid #d1d5db;border-radius:.25rem;font-size:.875rem;background:#fff;cursor:pointer;transition:all .2s;min-width:100px}.status-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;color:#64748b}@media (max-width: 768px){.bookshelf-books-modal{width:95%;max-height:95vh}.bulk-actions{flex-direction:column;align-items:stretch;gap:.5rem}.books-container{padding:1rem;overflow-x:auto}.books-table{min-width:600px}.book-info{max-width:200px}}.bookshelf-manager{width:100%}.create-button{background:#10b981;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;box-shadow:0 1px 3px #0000001a}.create-button:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.create-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.form-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}.form-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.form-container{background:#fff;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;position:relative;z-index:1001}.form-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 0;border-bottom:1px solid #e2e8f0;margin-bottom:1.5rem}.form-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#1e293b}.close-button{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.5rem;border-radius:.25rem;color:#6b7280}.close-button:hover{background:#f3f4f6;color:#374151}.bookshelf-form{padding:0 1.5rem 1.5rem}.form-row{display:grid;grid-template-columns:1fr 150px;gap:1rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151;font-size:.875rem}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;transition:all .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:400!important}.checkbox-label input[type=checkbox]{width:auto;margin:0}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.cancel-button{background:#f8fafc;color:#475569;border:1px solid #cbd5e1;padding:.75rem 1.5rem;border-radius:.375rem;font-weight:500;cursor:pointer;transition:all .2s}.cancel-button:hover{background:#e2e8f0}.submit-button{background:#3b82f6;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.375rem;font-weight:500;cursor:pointer;transition:all .2s}.submit-button:hover:not(:disabled){background:#2563eb}.submit-button:disabled{opacity:.6;cursor:not-allowed}.bookshelves-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.bookshelf-card{background:#fff;border:1px solid #e2e8f0;border-left:4px solid #3b82f6;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;transition:all .2s;cursor:pointer;position:relative}.bookshelf-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.bookshelf-card:active:not(:has(.bookshelf-actions button:active)){transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.bookshelf-card[draggable=true]{cursor:grab}.bookshelf-card[draggable=true]:active{cursor:grabbing}.bookshelf-card.dragging{opacity:.5;transform:scale(.95)}.bookshelf-card:not(.dragging){transition:transform .2s,opacity .2s}.bookshelf-card.drag-over{border:2px dashed #3b82f6;background:#eff6ff;transform:scale(1.02)}.bookshelf-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.bookshelf-title{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.bookshelf-icon{font-size:1.5rem;flex-shrink:0}.bookshelf-title h3{margin:0;font-size:1.125rem;font-weight:600;color:#1e293b;flex:1;min-width:0;word-break:break-word}.public-badge{background:#dbeafe;color:#1e40af;font-size:.75rem;font-weight:500;padding:.25rem .5rem;border-radius:.25rem;flex-shrink:0}.bookshelf-actions{display:flex;gap:.5rem;flex-shrink:0}.action-button{background:none;border:none;padding:.5rem;border-radius:.25rem;cursor:pointer;transition:all .2s;font-size:1rem}.edit-button:hover{background:#dbeafe}.bookshelf-description{margin:0 0 1rem;color:#64748b;font-size:.875rem;line-height:1.5}.bookshelf-location{color:#6b7280;font-size:.875rem;margin-bottom:1rem;display:flex;align-items:center;gap:.25rem}.bookshelf-stats{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;padding:.75rem;background:#f8fafc;border-radius:.375rem;font-size:.875rem}.stat-item{display:flex;align-items:center;gap:.25rem;color:#475569;font-weight:500}.stat-item.available{color:#059669}.stat-item.borrowed{color:#d97706}.bookshelf-meta{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:#9ca3af;border-top:1px solid #f1f5f9;padding-top:1rem;margin-top:1rem}.empty-state{grid-column:1 / -1;text-align:center;padding:4rem 2rem;background:#fff;border-radius:.75rem;border:2px dashed #d1d5db}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{margin:0 0 .5rem;color:#374151;font-size:1.25rem;font-weight:600}.empty-state p{margin:0 0 2rem;color:#6b7280}@media (max-width: 768px){.manager-header{flex-direction:column;align-items:stretch;gap:1rem}.bookshelves-grid{grid-template-columns:1fr;gap:1rem}.form-container{margin:0;border-radius:0;max-height:100vh}.form-row{grid-template-columns:1fr}.bookshelf-header{flex-direction:column;align-items:flex-start;gap:.75rem}.bookshelf-actions{align-self:flex-end}.bookshelf-meta{flex-direction:column;align-items:flex-start;gap:.25rem}}.advanced-book-manager{width:100%}.header-actions{display:flex;gap:.75rem;flex-wrap:wrap}.filter-toggle,.export-button,.import-button{padding:.5rem 1rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.filter-toggle{background:#3b82f6;color:#fff}.filter-toggle:hover{background:#2563eb}.export-button{background:#10b981;color:#fff}.export-button:hover{background:#059669}.import-button{background:#f59e0b;color:#fff}.import-button:hover{background:#d97706}.filters-panel{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e2e8f0}.panel-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#1e293b}.panel-actions{display:flex;gap:.5rem}.panel-actions button{background:none;border:1px solid #d1d5db;padding:.375rem .75rem;border-radius:.25rem;font-size:.875rem;cursor:pointer;transition:all .2s}.panel-actions button:hover{background:#f3f4f6}.filters-grid{padding:1.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.875rem;font-weight:500;color:#374151}.filter-group input,.filter-group select{padding:.5rem;border:1px solid #d1d5db;border-radius:.25rem;font-size:.875rem;transition:all .2s}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.sort-controls{display:flex;gap:.5rem}.sort-controls select{flex:1}.date-range{grid-column:span 2}.date-inputs{display:flex;align-items:center;gap:.5rem}.date-inputs input{flex:1}.date-inputs span{color:#6b7280;font-size:.875rem}.tags-filter{grid-column:1 / -1}.tags-selection{display:flex;flex-wrap:wrap;gap:.5rem}.tag-checkbox{display:flex;align-items:center;gap:.25rem;cursor:pointer;-webkit-user-select:none;user-select:none}.tag-checkbox input{margin:0;width:auto}.tag-checkbox span{padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500;color:#fff;opacity:.6;transition:opacity .2s}.tag-checkbox input:checked+span{opacity:1}.bulk-edit-panel{background:#eff6ff;border:1px solid #bfdbfe;border-radius:.5rem;margin-bottom:2rem}.bulk-edit-form{padding:1.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:#1e40af}.form-group select{padding:.5rem;border:1px solid #bfdbfe;border-radius:.25rem;background:#fff;font-size:.875rem}.bulk-actions{grid-column:1 / -1;display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem;padding-top:1rem;border-top:1px solid #bfdbfe}.bulk-actions button{padding:.5rem 1rem;border:none;border-radius:.25rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.bulk-actions button:first-child{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.bulk-actions button:first-child:hover{background:#e5e7eb}.apply-button{background:#1d4ed8!important;color:#fff!important}.apply-button:hover{background:#1e40af!important}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:#fff;border-radius:.5rem;box-shadow:0 20px 25px -5px #0000001a;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 0;margin-bottom:1rem}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#1e293b}.modal-header button{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.5rem;border-radius:.25rem;color:#6b7280}.modal-header button:hover{background:#f3f4f6}.modal-content{padding:0 1.5rem 1.5rem}.export-options{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.export-option{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;padding:1rem;cursor:pointer;transition:all .2s;text-align:left;display:flex;flex-direction:column;gap:.25rem}.export-option:hover{background:#f1f5f9;border-color:#cbd5e1}.export-option small{color:#64748b;font-size:.75rem}.results-section{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 1px 3px #0000001a}.results-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e2e8f0}.results-info{display:flex;align-items:center;gap:1rem}.results-info span{font-size:.875rem;color:#64748b}.selection-info{color:#3b82f6!important;font-weight:500!important}.selection-info button{background:none;border:none;color:#3b82f6;text-decoration:underline;cursor:pointer;margin-left:.5rem}.selection-controls button{background:#f8fafc;border:1px solid #e2e8f0;padding:.375rem .75rem;border-radius:.25rem;font-size:.875rem;cursor:pointer;transition:all .2s}.selection-controls button:hover{background:#f1f5f9}.books-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;padding:1.5rem}.book-card{border:1px solid #e2e8f0;border-radius:.5rem;padding:1rem;transition:all .2s;cursor:pointer;position:relative}.book-card:hover{border-color:#cbd5e1;box-shadow:0 4px 6px -1px #0000001a}.book-card.selected{border-color:#3b82f6;background:#eff6ff}.book-selection{position:absolute;top:.5rem;left:.5rem}.book-selection input{margin:0}.book-cover{width:60px;height:90px;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center}.book-cover img{width:100%;height:100%;object-fit:cover;border-radius:.25rem;box-shadow:0 1px 3px #0000001a}.no-cover{width:100%;height:100%;background:#f3f4f6;border-radius:.25rem;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#9ca3af}.book-info h4{margin:0 0 .5rem;font-size:.875rem;font-weight:600;color:#1e293b;line-height:1.3}.book-info .author{margin:0 0 .25rem;font-size:.75rem;color:#6b7280}.book-info .bookshelf{margin:0 0 .5rem;font-size:.75rem;color:#059669}.book-tags{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.5rem}.tag{padding:.125rem .25rem;border-radius:.25rem;font-size:.625rem;font-weight:500;color:#fff}.book-info .status{margin:0;font-size:.75rem;font-weight:500;color:#374151}.no-results{text-align:center;padding:4rem 2rem;color:#6b7280}.no-results-icon{font-size:4rem;margin-bottom:1rem}.no-results h3{margin:0 0 .5rem;color:#374151;font-size:1.125rem;font-weight:600}.no-results p{margin:0;font-size:.875rem}@media (max-width: 1024px){.filters-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.books-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}@media (max-width: 768px){.manager-header{flex-direction:column;align-items:stretch;gap:1rem}.header-actions{justify-content:stretch}.filter-toggle,.export-button,.import-button{flex:1;text-align:center}.filters-grid{grid-template-columns:1fr;gap:.75rem}.date-range,.tags-filter{grid-column:1}.bulk-edit-form{grid-template-columns:1fr}.results-header{flex-direction:column;align-items:stretch;gap:1rem}.results-info{flex-direction:column;align-items:flex-start;gap:.5rem}.books-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem;padding:1rem}.modal{margin:0;border-radius:0;max-height:100vh}}.book-manager{width:100%}.book-manager-tabs{display:flex;gap:0;margin-bottom:2rem;border-bottom:1px solid #e2e8f0}.tab-button{background:none;border:none;padding:1rem 1.5rem;border-bottom:2px solid transparent;color:#64748b;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;white-space:nowrap}.delete-selected-button{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;margin-left:auto}.delete-selected-button:hover{background:#dc2626}.books-table-container{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;overflow:hidden}.books-table{width:100%;border-collapse:collapse}.books-table th{background:#f8fafc;padding:1rem .75rem;text-align:left;font-weight:600;color:#374151;font-size:.875rem;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:10}.books-table td{padding:1rem .75rem;border-bottom:1px solid #f1f5f9;vertical-align:top}.books-table tr:hover{background:#f8fafc}.books-table tr.selected{background:#eff6ff}.books-table tr.selected:hover{background:#dbeafe}.book-cover{width:40px;height:60px;object-fit:cover;border-radius:.25rem;box-shadow:0 1px 3px #0000001a}.no-cover{width:40px;height:60px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border-radius:.25rem;font-size:1.5rem;color:#9ca3af}.book-info{max-width:250px}.book-author,.book-isbn,.book-publisher{font-size:.875rem;color:#6b7280;line-height:1.4;margin-bottom:.125rem}.bookshelf-select,.status-select{padding:.375rem .5rem;border:1px solid #d1d5db;border-radius:.25rem;font-size:.875rem;background:#fff;cursor:pointer;transition:all .2s;width:100%;max-width:150px}.bookshelf-select:focus,.status-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.status-select.status-available{border-color:#10b981;background:#f0fdf4;color:#059669}.status-select.status-borrowed{border-color:#f59e0b;background:#fffbeb;color:#d97706}.status-select.status-lost,.status-select.status-damaged{border-color:#ef4444;background:#fef2f2;color:#dc2626}.status-select.status-reserved{border-color:#8b5cf6;background:#faf5ff;color:#7c3aed}.created-date{font-size:.875rem;color:#6b7280;white-space:nowrap}.delete-button{background:none;border:none;padding:.5rem;border-radius:.25rem;cursor:pointer;transition:all .2s;font-size:1rem}.delete-button:hover{background:#fef2f2}.no-books{text-align:center;padding:3rem 1rem;color:#6b7280;font-style:italic}@media (max-width: 1024px){.books-table-container{overflow-x:auto}.books-table{min-width:800px}}@media (max-width: 768px){.manager-header{flex-direction:column;align-items:stretch;gap:1rem}.header-stats{text-align:left;flex-direction:row;gap:1rem}.filter-controls{flex-direction:column;align-items:stretch}.filter-select{width:100%}.delete-selected-button{margin-left:0}.books-table th,.books-table td{padding:.75rem .5rem}.book-info{max-width:200px}}@media (max-width: 480px){.filters-section{padding:1rem}.books-table th,.books-table td{padding:.5rem .25rem}.book-cover,.no-cover{width:30px;height:45px}.book-info{max-width:150px}.book-title{font-size:.875rem}.book-author,.book-isbn,.book-publisher{font-size:.75rem}}.lending-manager{width:100%}.manager-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.header-content h2{margin:0 0 .5rem;font-size:1.875rem;font-weight:700;color:#1e293b}.header-description{margin:0;color:#64748b;font-size:1rem}.header-stats{display:flex;flex-direction:column;gap:.25rem;text-align:right}.stat{font-size:.875rem;color:#6b7280;font-weight:500}.stat.active{color:#f59e0b;font-weight:600}.stat.overdue{color:#ef4444;font-weight:600}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:.75rem 1rem;margin-bottom:1.5rem;border-radius:.5rem;display:flex;justify-content:space-between;align-items:center}.error-message button{background:none;border:none;color:#991b1b;cursor:pointer;padding:.25rem;border-radius:.25rem}.error-message button:hover{background:#fecaca}.overdue-alert{background:#fef3cd;border:1px solid #fde68a;color:#92400e;padding:.75rem 1rem;margin-bottom:1.5rem;border-radius:.5rem;font-weight:500}.filters-section{background:#fff;padding:1.5rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;margin-bottom:1.5rem}.search-box{margin-bottom:1rem}.search-input{width:100%;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;transition:all .2s}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.filter-controls{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.filter-select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;background:#fff;cursor:pointer;transition:all .2s}.filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.lendings-table-container{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;overflow:hidden}.lendings-table{width:100%;border-collapse:collapse}.lendings-table th{background:#f8fafc;padding:1rem .75rem;text-align:left;font-weight:600;color:#374151;font-size:.875rem;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:10}.lendings-table td{padding:1rem .75rem;border-bottom:1px solid #f1f5f9;vertical-align:top}.lendings-table tr:hover{background:#f8fafc}.lendings-table tr.overdue-row{background:#fef2f2}.lendings-table tr.overdue-row:hover{background:#fecaca}.book-info{max-width:200px}.book-title{display:block;color:#1e293b;font-weight:600;line-height:1.3;margin-bottom:.25rem}.book-author,.book-isbn{font-size:.875rem;color:#6b7280;line-height:1.4;margin-bottom:.125rem}.book-isbn{font-family:monospace;font-size:.75rem}.borrower-info{max-width:150px}.borrower-info strong{display:block;color:#1e293b;font-weight:600;margin-bottom:.25rem}.borrower-email{font-size:.875rem;color:#6b7280;word-break:break-all}.date-cell{font-size:.875rem;color:#6b7280;white-space:nowrap}.due-date{display:flex;flex-direction:column;gap:.25rem}.due-date.overdue{color:#dc2626;font-weight:600}.due-days{font-size:.75rem;color:#6b7280;font-weight:500}.due-date.overdue .due-days{color:#dc2626;font-weight:600}.no-due-date{color:#9ca3af;font-style:italic}.status-badge{display:inline-block;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.status-badge.status-active{background:#fef3cd;color:#92400e}.status-badge.status-returned{background:#d1fae5;color:#065f46}.status-badge.overdue{background:#fecaca;color:#991b1b}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.return-button,.extend-button{padding:.375rem .75rem;border:none;border-radius:.25rem;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.25rem;white-space:nowrap}.return-button{background:#10b981;color:#fff}.return-button:hover:not(:disabled){background:#059669}.extend-button{background:#f59e0b;color:#fff}.extend-button:hover:not(:disabled){background:#d97706}.return-button:disabled,.extend-button:disabled{opacity:.6;cursor:not-allowed}.returned-text{font-size:.75rem;color:#059669;font-weight:500}.no-lendings{text-align:center;padding:3rem 1rem;color:#6b7280;font-style:italic}@media (max-width: 1024px){.lendings-table-container{overflow-x:auto}.lendings-table{min-width:900px}}@media (max-width: 768px){.manager-header{flex-direction:column;align-items:stretch;gap:1rem}.header-stats{text-align:left;flex-direction:row;gap:1rem;flex-wrap:wrap}.filter-controls{flex-direction:column;align-items:stretch}.filter-select{width:100%}.lendings-table th,.lendings-table td{padding:.75rem .5rem}.book-info,.borrower-info{max-width:150px}.action-buttons{flex-direction:column}}@media (max-width: 480px){.filters-section{padding:1rem}.lendings-table th,.lendings-table td{padding:.5rem .25rem}.book-info,.borrower-info{max-width:120px}.book-title{font-size:.875rem}.book-author,.book-isbn{font-size:.75rem}.return-button,.extend-button{padding:.25rem .5rem;font-size:.7rem}}.admin-panel{min-height:100vh;background:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.admin-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #0000001a}.admin-header h1{margin:0;font-size:1.5rem;font-weight:600;color:#1e293b}.header-actions{display:flex;gap:.75rem}.refresh-button{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.refresh-button:hover:not(:disabled){background:#2563eb}.refresh-button:disabled{opacity:.6;cursor:not-allowed}.error-banner{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:.75rem 1rem;margin:1rem 2rem;border-radius:.375rem;display:flex;justify-content:space-between;align-items:center}.error-banner button{background:none;border:none;color:#991b1b;cursor:pointer;padding:.25rem;border-radius:.25rem}.error-banner button:hover{background:#fecaca}.admin-nav{background:#fff;border-bottom:1px solid #e2e8f0;padding:0 2rem}.tab-list{display:flex;gap:0;overflow-x:auto}.tab-button{background:none;border:none;padding:1rem 1.5rem;border-bottom:2px solid transparent;color:#64748b;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem;white-space:nowrap;font-size:.875rem;font-weight:500;position:relative}.tab-button:hover{color:#1e293b;background:#f8fafc}.tab-button.active{color:#3b82f6;border-bottom-color:#3b82f6;background:#eff6ff}.tab-icon{font-size:1rem}.tab-badge{background:#ef4444;color:#fff;font-size:.75rem;font-weight:600;padding:.125rem .375rem;border-radius:9999px;min-width:1.25rem;text-align:center;line-height:1.2}.tab-button.active .tab-badge{background:#3b82f6}.admin-content{padding:2rem;max-width:1400px;margin:0 auto}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#64748b}.spinner{width:2rem;height:2rem;border:2px solid #e2e8f0;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.admin-header{padding:1rem;flex-direction:column;gap:1rem;align-items:stretch}.admin-header h1{font-size:1.25rem;text-align:center}.admin-nav{padding:0 1rem}.tab-list{justify-content:space-around}.tab-button{padding:.75rem .5rem;font-size:.75rem;flex-direction:column;gap:.25rem}.tab-label{display:none}.admin-content{padding:1rem}}@media (max-width: 480px){.tab-button{padding:.5rem .25rem}.tab-icon{font-size:1.25rem}}.app{min-height:100vh;background:#f5f5f5}.app-header{background:#fff;box-shadow:0 2px 4px #0000001a;padding:20px;position:sticky;top:0;z-index:100}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.app-header h1{margin:0;color:#333;font-size:24px}.header-actions{display:flex;gap:10px}.admin-button{padding:8px 16px;background:#2196f3;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.admin-button:hover{background:#1976d2;transform:translateY(-1px)}.app-main{max-width:1200px;margin:0 auto;padding:20px}.error-message{background:#ffebee;border:1px solid #ffcdd2;border-radius:6px;padding:15px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.error-message p{margin:0;color:#c62828;white-space:pre-line}.error-message button{background:none;border:none;color:#c62828;font-size:20px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.input-section{background:#fff;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.action-buttons{display:flex;gap:10px;justify-content:center;margin-top:10px}.scan-button{padding:10px 20px;background:#ff9800;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;transition:background-color .2s}.scan-button:hover:not(:disabled){background:#f57c00}.scan-button:disabled{background:#ccc;cursor:not-allowed}.lending-button{padding:10px 20px;background:#4caf50;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;transition:background-color .2s}.lending-button:hover:not(:disabled){background:#45a049}.lending-button:disabled{background:#ccc;cursor:not-allowed}
