*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #EA580C;--primary-light: #FFF7ED;--primary-hover: #C2410C;--primary-muted: #FB923C;--bg: #F8FAFC;--card: #FFFFFF;--sidebar-bg: #FFFFFF;--border: #E2E8F0;--border-light: #F1F5F9;--text-primary: #1E293B;--text-secondary: #64748B;--text-muted: #94A3B8;--success: #10B981;--success-bg: #ECFDF5;--success-text:#065F46;--warning: #F59E0B;--warning-bg: #FFFBEB;--warning-text:#92400E;--danger: #EF4444;--danger-bg: #FEF2F2;--danger-text:#991B1B;--info: #3B82F6;--info-bg: #EFF6FF;--info-text: #1E40AF;--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);--shadow: 0 4px 6px -1px rgba(0,0,0,.07), 0 2px 4px -2px rgba(0,0,0,.05);--shadow-md: 0 10px 15px -3px rgba(0,0,0,.08), 0 4px 6px -4px rgba(0,0,0,.05);--shadow-lg: 0 20px 25px -5px rgba(0,0,0,.08), 0 8px 10px -6px rgba(0,0,0,.05);--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--radius-xl: 20px;--sidebar-width: 248px}html,body,#root{height:100%;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;color:var(--text-primary);background:var(--bg);-webkit-font-smoothing:antialiased}.app-layout{display:flex;height:100vh;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.page-body{flex:1;overflow-y:auto;padding:24px 28px}.sidebar{width:var(--sidebar-width);height:100vh;background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.sidebar-header{padding:20px 20px 16px;border-bottom:1px solid var(--border-light)}.sidebar-brand{display:flex;align-items:center;gap:10px;text-decoration:none}.brand-icon{width:36px;height:36px;background:var(--primary);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.brand-name{font-size:15px;font-weight:700;color:var(--text-primary);line-height:1.2}.brand-sub{font-size:11px;color:var(--text-muted);font-weight:400}.sidebar-nav{flex:1;padding:12px;display:flex;flex-direction:column;gap:2px}.nav-section-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:12px 8px 6px}.nav-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);text-decoration:none;color:var(--text-secondary);font-weight:500;font-size:13.5px;transition:all .15s ease;cursor:pointer;border:none;background:none;width:100%;text-align:left}.nav-link:hover{background:var(--primary-light);color:var(--primary)}.nav-link.active{background:var(--primary-light);color:var(--primary);font-weight:600}.nav-link-icon{width:18px;height:18px;flex-shrink:0}.sidebar-footer{padding:16px 20px;border-top:1px solid var(--border-light);font-size:12px;color:var(--text-muted);text-align:center}.topbar{height:60px;background:var(--card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 28px;flex-shrink:0}.topbar-left h1{font-size:17px;font-weight:700;color:var(--text-primary)}.topbar-left p{font-size:12px;color:var(--text-muted);margin-top:1px}.topbar-right{display:flex;align-items:center;gap:8px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 0}.card-title{font-size:14px;font-weight:600;color:var(--text-primary)}.card-body{padding:16px 20px 20px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;display:flex;align-items:flex-start;gap:14px;box-shadow:var(--shadow-xs);transition:box-shadow .2s}.stat-card:hover{box-shadow:var(--shadow-sm)}.stat-icon{width:42px;height:42px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.indigo{background:var(--primary-light);color:var(--primary)}.stat-icon.green{background:var(--success-bg);color:var(--success)}.stat-icon.amber{background:var(--warning-bg);color:var(--warning)}.stat-icon.red{background:var(--danger-bg);color:var(--danger)}.stat-info{flex:1}.stat-label{font-size:12px;color:var(--text-secondary);font-weight:500}.stat-value{font-size:26px;font-weight:700;color:var(--text-primary);line-height:1.1;margin:3px 0}.stat-sub{font-size:11px;color:var(--text-muted)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .15s ease;text-decoration:none;white-space:nowrap;font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover)}.btn-secondary{background:var(--card);color:var(--text-secondary);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg);color:var(--text-primary)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:#fecaca}.btn-danger:hover:not(:disabled){background:#fee2e2}.btn-success{background:var(--success-bg);color:var(--success);border-color:#a7f3d0}.btn-success:hover:not(:disabled){background:#d1fae5}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--border-light);color:var(--text-primary)}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{padding:7px}.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:16px}.form-label{font-size:12.5px;font-weight:600;color:var(--text-secondary)}.form-input,.form-select,.form-textarea{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13.5px;color:var(--text-primary);background:var(--card);font-family:inherit;transition:border-color .15s,box-shadow .15s;outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ea580c1f}.form-textarea{resize:vertical;min-height:80px}.form-hint{font-size:11.5px;color:var(--text-muted)}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--card);box-shadow:var(--shadow-xs)}table{width:100%;border-collapse:collapse}thead th{padding:10px 16px;text-align:left;font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:var(--bg);border-bottom:1px solid var(--border);white-space:nowrap}tbody td{padding:13px 16px;border-bottom:1px solid var(--border-light);font-size:13.5px;color:var(--text-primary)}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#fafbfd}.td-muted{color:var(--text-secondary);font-size:12.5px}.td-actions{display:flex;gap:4px;align-items:center}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:999px;font-size:11.5px;font-weight:600;white-space:nowrap}.badge-green{background:var(--success-bg);color:var(--success-text)}.badge-amber{background:var(--warning-bg);color:var(--warning-text)}.badge-red{background:var(--danger-bg);color:var(--danger-text)}.badge-blue{background:var(--info-bg);color:var(--info-text)}.badge-gray{background:#f1f5f9;color:#475569}.badge-indigo{background:var(--primary-light);color:var(--primary)}.page-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.search-box{position:relative;flex:1;max-width:340px}.search-box input{width:100%;padding:8px 12px 8px 36px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13.5px;color:var(--text-primary);background:var(--card);font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s}.search-box input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ea580c1f}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.filter-tabs{display:flex;gap:4px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px}.filter-tab{padding:5px 12px;border-radius:5px;font-size:12.5px;font-weight:500;cursor:pointer;border:none;background:none;color:var(--text-secondary);transition:all .15s;font-family:inherit}.filter-tab.active{background:var(--card);color:var(--primary);box-shadow:var(--shadow-xs);font-weight:600}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}.modal{background:var(--card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:540px;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}.modal-title{font-size:16px;font-weight:700;color:var(--text-primary)}.modal-body{padding:18px 24px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:0 24px 20px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:56px 20px;gap:12px;text-align:center}.empty-icon{width:56px;height:56px;background:var(--bg);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin-bottom:4px}.empty-state h3{font-size:15px;font-weight:600;color:var(--text-primary)}.empty-state p{font-size:13px;color:var(--text-secondary);max-width:280px}.toast-container{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;gap:8px}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#1e293b;color:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);font-size:13.5px;font-weight:500;min-width:260px;animation:slideUp .25s ease}.toast.success{background:#064e3b}.toast.error{background:#7f1d1d}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.page-loading{display:flex;align-items:center;justify-content:center;padding:60px;gap:10px;color:var(--text-muted)}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.recent-list{display:flex;flex-direction:column;gap:0}.recent-item{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border-light);transition:background .1s}.recent-item:last-child{border-bottom:none}.recent-item:hover{background:#fafbfd}.recent-avatar{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--primary-light);display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:13px;font-weight:700;flex-shrink:0}.recent-info{flex:1;min-width:0}.recent-title{font-size:13.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-sub{font-size:12px;color:var(--text-muted)}.page-header{margin-bottom:20px}.page-header h2{font-size:20px;font-weight:700}.page-header p{font-size:13px;color:var(--text-secondary);margin-top:3px}.text-right{text-align:right}.text-center{text-align:center}.flex{display:flex}.flex-center{display:flex;align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.mb-4{margin-bottom:16px}.mt-2{margin-top:8px}.divider{border:none;border-top:1px solid var(--border-light);margin:16px 0}.book-cover{width:36px;height:48px;border-radius:4px;object-fit:cover;background:linear-gradient(135deg,var(--primary-light) 0%,#FED7AA 100%);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;overflow:hidden}.scanner-wrap{position:relative;border-radius:var(--radius);overflow:hidden;background:#000;line-height:0}.scanner-video{width:100%;height:220px;object-fit:cover;display:block}.scanner-line{position:absolute;left:12%;right:12%;height:3px;background:var(--primary);box-shadow:0 0 10px var(--primary),0 0 20px var(--primary-muted);border-radius:2px;animation:scanLine 1.8s ease-in-out infinite}@keyframes scanLine{0%,to{top:20%}50%{top:78%}}.scanner-corners:before,.scanner-corners:after{content:"";position:absolute;width:22px;height:22px;border-color:var(--primary);border-style:solid;border-width:0}.scanner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px}.scanner-hint{position:absolute;bottom:10px;left:0;right:0;text-align:center;color:#ffffffd9;font-size:12px;font-weight:500}.isbn-row{display:flex;gap:8px;align-items:flex-end}.isbn-row .form-input{flex:1}.modal-tabs{display:flex;border-bottom:1px solid var(--border);margin:0 24px;gap:0}.modal-tab{padding:10px 16px;font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-1px;font-family:inherit;transition:all .15s;display:flex;align-items:center;gap:6px}.modal-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.cover-preview{display:flex;gap:12px;align-items:flex-start;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:4px}.cover-img{width:52px;height:68px;border-radius:4px;object-fit:cover;box-shadow:var(--shadow-sm);background:var(--border-light);flex-shrink:0}.cover-info{flex:1;min-width:0}.cover-info strong{font-size:13px;font-weight:600;display:block}.cover-info span{font-size:12px;color:var(--text-secondary)}.loans-in-books{display:flex;flex-direction:column;gap:3px}.borrower-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;background:var(--primary-light);color:var(--primary);border-radius:999px;font-size:11px;font-weight:600;white-space:nowrap}.borrower-tag.overdue{background:var(--danger-bg);color:var(--danger)}.cover-picker{display:flex;gap:16px;align-items:flex-start;padding:14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius)}.cover-picker-preview{width:80px;height:108px;border-radius:6px;flex-shrink:0;overflow:hidden;position:relative;background:var(--border-light);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.cover-picker-img{width:100%;height:100%;object-fit:cover;display:block}.cover-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:var(--border-light)}.cover-picker-ok{position:absolute;bottom:0;left:0;right:0;background:#10b981e6;color:#fff;font-size:9px;font-weight:600;padding:3px 4px;text-align:center;display:flex;align-items:center;justify-content:center;gap:3px}.cover-picker-controls{flex:1;min-width:0;display:flex;flex-direction:column;gap:0}.cover-picker-label{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.cover-source-btns{display:flex;gap:6px;flex-wrap:wrap}.cover-source-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-sm);font-size:12.5px;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--card);color:var(--text-secondary);font-family:inherit;transition:all .15s;white-space:nowrap}.cover-source-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.cover-source-btn:disabled{opacity:.5;cursor:not-allowed}.cover-source-btn.loading{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.source-logo{width:18px;height:18px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;flex-shrink:0}.source-logo.google{background:#4285f4;color:#fff}.source-logo.ol{background:#e8490f;color:#fff}.books-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.book-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .15s,transform .15s}.book-card:hover{box-shadow:0 4px 16px #00000014;transform:translateY(-2px)}.book-card-cover{height:200px;background:var(--bg-secondary);position:relative;overflow:hidden;flex-shrink:0}.book-card-cover img{width:100%;height:100%;object-fit:cover;display:block}.book-card-body{padding:10px 12px;flex:1}.book-card-title{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-card-author{font-size:11.5px;color:var(--text-muted);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-card-actions{display:flex;justify-content:flex-end;gap:4px;padding:6px 8px;border-top:1px solid var(--border);background:var(--bg-secondary)}
