@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Noto+Sans+Arabic:wght@300;400;500;600;700;800&display=swap";.feedback-modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.feedback-modal{background:#fff;border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040}.feedback-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-subtle)}.feedback-modal-header h2{font-size:1.25rem;font-weight:700;color:var(--text-main);margin:0}.feedback-close-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:var(--bg-main);border-radius:8px;color:var(--text-muted);cursor:pointer;transition:all .2s}.feedback-close-btn:hover{background:#ef44441a;color:#ef4444}.feedback-form{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.feedback-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}@media(max-width:480px){.feedback-type-grid{grid-template-columns:1fr}}.feedback-type-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem .75rem;background:#fff;border:2px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;text-align:center}.feedback-type-btn:hover{border-color:var(--brand-light);background:var(--brand-subtle)}.feedback-type-btn.active{border-color:var(--brand);background:var(--brand-subtle);color:var(--brand)}.feedback-type-btn svg{color:var(--text-muted)}.feedback-type-btn.active svg{color:var(--brand)}.type-label{font-size:.875rem;font-weight:700;color:var(--text-main)}.feedback-type-btn.active .type-label{color:var(--brand)}.type-desc{font-size:.7rem;color:var(--text-muted);line-height:1.3}.feedback-field{display:flex;flex-direction:column;gap:.5rem}.feedback-field label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.feedback-field input,.feedback-field textarea{padding:.75rem 1rem;border:1px solid var(--border-subtle);border-radius:var(--radius-md);font-size:.95rem;font-family:inherit;color:var(--text-main);transition:all .2s;resize:vertical}.feedback-field input:focus,.feedback-field textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-subtle)}.feedback-field input::placeholder,.feedback-field textarea::placeholder{color:var(--text-dim)}.feedback-submit-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;background:var(--brand);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem}.feedback-submit-btn:hover:not(:disabled){background:var(--brand-dark);transform:translateY(-1px)}.feedback-submit-btn:disabled{opacity:.6;cursor:not-allowed}.feedback-success{padding:3rem 2rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:1rem}.feedback-success .success-icon{color:#22c55e}.feedback-success h3{font-size:1.5rem;font-weight:700;color:var(--text-main);margin:0}.feedback-success p{color:var(--text-muted);margin:0}.notification-bell-container{position:relative}.notification-bell-button{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:10px;background:var(--glass-bg);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.notification-bell-button:hover{background:var(--glass-bg-hover);color:var(--text-primary);transform:scale(1.05)}.notification-bell-button:active{transform:scale(.98)}.notification-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--danger);color:#fff;font-size:11px;font-weight:600;line-height:18px;text-align:center;box-shadow:0 2px 8px #ef444466;animation:notification-pulse 2s infinite}@keyframes notification-pulse{0%,to{box-shadow:0 2px 8px #ef444466}50%{box-shadow:0 2px 16px #ef444499}}.notification-dropdown{position:fixed;top:auto;left:16px;right:auto;width:360px;max-height:480px;background:#fffffffa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 10px 40px #0003,0 0 0 1px #0000000d;z-index:9999;display:flex;flex-direction:column;animation:notification-dropdown-enter .2s ease;overflow:hidden}[data-theme=dark] .notification-dropdown{background:#1e1e28fa}@keyframes notification-dropdown-enter{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.notification-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.notification-dropdown-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.notification-action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.notification-action-btn:hover{background:var(--glass-bg-hover);color:var(--brand)}.notification-dropdown-content{flex:1;overflow-y:auto;max-height:360px}.notification-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:var(--text-muted)}.notification-empty svg{margin-bottom:12px;opacity:.5}.notification-empty p{margin:0;font-size:14px}.notification-list{padding:8px}.notification-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:12px;cursor:pointer;transition:all .2s ease;position:relative}.notification-item:hover{background:var(--glass-bg-hover)}.notification-item:hover .notification-item-actions{opacity:1}.notification-unread{background:rgba(var(--brand-rgb),.08)}.notification-unread:before{content:"";position:absolute;left:4px;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:50%;background:var(--brand)}.notification-item-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:var(--glass-bg)}.notification-icon-user{background:#3b82f626;color:#3b82f6}.notification-icon-feedback{background:#a855f726;color:#a855f7}.notification-icon-system{background:rgba(var(--brand-rgb),.15);color:var(--brand)}.notification-item-content{flex:1;min-width:0}.notification-item-title{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.notification-item-message{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.notification-item-time{font-size:11px;color:var(--text-muted)}.notification-item-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s ease}.notification-item-action{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.notification-item-action:hover{background:var(--glass-bg);color:var(--text-primary)}.notification-item-dismiss:hover{color:var(--danger)}.notification-dropdown-footer{padding:12px 16px;border-top:1px solid var(--border-color)}.notification-clear-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:8px 12px;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s ease}.notification-clear-btn:hover{background:#ef44441a;color:var(--danger)}@media(max-width:480px){.notification-dropdown{position:fixed;inset:auto 0 0;width:100%;max-height:70vh;border-radius:24px 24px 0 0;animation:notification-slide-up .3s ease}@keyframes notification-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.notification-dropdown-header{padding:20px 24px 16px}.notification-dropdown-header:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:36px;height:4px;border-radius:2px;background:var(--border-color)}.notification-list{padding:12px}.notification-item{padding:14px}.notification-item-actions{opacity:1}}.notification-dropdown-content::-webkit-scrollbar{width:6px}.notification-dropdown-content::-webkit-scrollbar-track{background:transparent}.notification-dropdown-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.notification-dropdown-content::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.sidebar-logo-group{display:flex;align-items:center;gap:1rem;text-decoration:none;color:inherit;flex:1}.ml-auto{margin-left:auto;display:flex;align-items:center}.sidebar-lang{padding:0 1rem;margin-top:1.5rem;margin-bottom:.5rem;position:relative;width:100%}.sidebar-nav{flex:1;padding:0 .75rem;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;color:var(--text-muted);font-size:.925rem;font-weight:600;text-decoration:none;border-radius:12px;margin-bottom:.25rem;transition:all .15s ease}.nav-item:hover{background:#6366f114;color:var(--text-main)}.nav-item.active{background:var(--brand-subtle);color:var(--brand);font-weight:700}.nav-item svg{flex-shrink:0}@media(max-width:1024px){.sidebar{position:fixed;transform:translate(-100%);box-shadow:20px 0 40px #0000001a}[dir=rtl] .sidebar{transform:translate(100%)}.sidebar.open{transform:translate(0)}}.sidebar-user-info{display:flex;align-items:center;gap:.75rem;padding:.875rem;margin-bottom:.5rem;width:100%;background:transparent;border:1px solid transparent;border-radius:12px;transition:all .2s ease;min-width:0}.sidebar-user-info:hover{background:#6366f114}.sidebar-user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--brand-subtle);display:flex;align-items:center;justify-content:center;color:var(--brand);border:2px solid white}.sidebar-user-details{display:flex;flex-direction:column;overflow:hidden;min-width:0;flex:1}.sidebar-user-name{font-size:.8125rem;font-weight:600;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2;max-width:100%}.sidebar-user-email{font-size:.6875rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2;max-width:100%}.sidebar-signout{margin-top:0;padding-top:0}.volume-manager{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:1.25rem;margin-top:1rem}.volume-manager-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-subtle)}.volume-manager-title{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--text-main)}.volume-manager-stats{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--text-muted)}.volume-stat strong{color:var(--brand)}.volume-stat-sep{color:var(--border-subtle)}.volume-total-input{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.875rem;background:var(--bg-main);border-radius:var(--radius-lg)}.volume-total-input label{font-size:.875rem;font-weight:500;color:var(--text-muted);white-space:nowrap}.volume-total-input input{width:80px;padding:.5rem .75rem;border:1px solid var(--border-subtle);border-radius:var(--radius-md);font-size:.9375rem;font-weight:600;text-align:center}.volume-total-input input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #4f46e51a}.volume-list{display:flex;flex-direction:column;gap:.75rem;width:100%}.volume-group{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);width:100%;box-sizing:border-box}.volume-group-header{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:linear-gradient(to right,#f8fafccc,#fff0);border-bottom:1px solid var(--border-subtle);font-size:.95rem;font-weight:600;color:var(--text-main);border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg)}.volume-add-copy-btn{margin-inline-start:auto;display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:transparent;border:1px solid rgba(79,70,229,.3);border-radius:var(--radius-md);font-size:.75rem;font-weight:500;color:var(--brand);cursor:pointer;transition:all .2s}.volume-add-copy-btn:hover{background:#4f46e51a}.volume-copies{display:flex;flex-direction:column}.volume-copy-row{display:flex;align-items:center;gap:1rem;padding:.875rem 1.25rem;border-bottom:1px solid var(--border-subtle);transition:background .2s;background:#fff;width:100%}.volume-copy-row:last-child{border-bottom:none;border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}.volume-copy-row:hover{background:#4f46e505}.volume-copy-row.editing{background:#4f46e50d}.volume-copy-info{display:flex;align-items:center;gap:.75rem;min-width:140px;flex-shrink:0;white-space:nowrap}.volume-copy-number{font-size:.8125rem;font-weight:600;color:var(--text-main)}.volume-copy-status{padding:.125rem .5rem;border-radius:9999px;font-size:.6875rem;font-weight:600;text-transform:uppercase}.volume-copy-status.status-available{background:#16a34a1a;color:#16a34a}.volume-copy-status.status-loaned{background:#f59e0b1a;color:#d97706}.volume-copy-status.status-lost{background:#ef44441a;color:#dc2626}.volume-copy-status.status-damaged{background:#6b72801a;color:#6b7280}.volume-copy-details{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.volume-detail{font-size:.8125rem;color:var(--text-muted);padding:.25rem .75rem;background:var(--bg-main);border-radius:var(--radius-md);white-space:nowrap}.volume-copy-edit{display:flex;align-items:center;gap:.5rem;flex:1;flex-wrap:wrap}.volume-edit-input{flex:1 1 80px;min-width:60px;max-width:120px;padding:.5rem .625rem;border:1px solid var(--border-subtle);border-radius:var(--radius-md);font-size:.8125rem}.volume-edit-input:focus{outline:none;border-color:var(--brand)}.volume-edit-select{padding:.5rem .625rem;border:1px solid var(--border-subtle);border-radius:var(--radius-md);font-size:.8125rem;background:#fff;min-width:70px;flex-shrink:0}.volume-edit-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all .2s;flex-shrink:0}.volume-edit-btn.save{background:var(--brand);color:#fff}.volume-edit-btn.save:hover{background:var(--brand-dark)}.volume-copy-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0;margin-inline-start:auto}.volume-action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .2s}.volume-action-btn:hover{background:var(--bg-main);color:var(--text-main)}.volume-action-btn.danger:hover{background:#ef44441a;color:#dc2626}.volume-empty{text-align:center;padding:1.5rem;color:var(--text-muted);font-size:.875rem}@media(max-width:640px){.volume-manager-header{flex-direction:column;align-items:flex-start;gap:.5rem}.volume-copy-row{flex-wrap:wrap}.volume-copy-details{width:100%;margin-top:.5rem}.volume-copy-edit{flex-wrap:wrap}.volume-edit-input{min-width:100px}}.volume-details-section{margin-top:2rem}.volume-details-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem;color:var(--text-muted)}.volume-stats-grid{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.volume-stat-card{display:flex;flex-direction:column;align-items:center;padding:.875rem 1.25rem;background:var(--bg-main);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);min-width:80px}.volume-stat-number{font-size:1.5rem;font-weight:700;color:var(--text-main);line-height:1}.volume-stat-label{font-size:.75rem;color:var(--text-muted);margin-top:.25rem;text-transform:uppercase;letter-spacing:.025em}.volume-stat-card.available .volume-stat-number{color:#16a34a}.volume-stat-card.loaned .volume-stat-number{color:#d97706}.volume-stat-card.lost .volume-stat-number{color:#dc2626}.volume-stat-card.damaged .volume-stat-number{color:#6b7280}.volume-list.details-variant{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);overflow:hidden}.volume-list.details-variant .volume-group{border-radius:0;border-left:none;border-right:none;border-top:none}.volume-list.details-variant .volume-group:last-child{border-bottom:none}.volume-edit-btn.cancel{background:var(--bg-main);color:var(--text-muted);border:1px solid var(--border-subtle)}.volume-edit-btn.cancel:hover{background:#ef44441a;color:#dc2626;border-color:#ef44444d}.volume-add-form{display:flex;align-items:center;gap:.5rem;padding:.625rem .875rem;background:#4f46e508;border-bottom:1px solid var(--border-subtle)}.volume-detail{display:inline-flex;align-items:center;gap:.25rem}.volume-detail svg{opacity:.6}@media(max-width:640px){.volume-stats-grid{gap:.5rem}.volume-stat-card{padding:.625rem .875rem;min-width:70px}.volume-stat-number{font-size:1.25rem}.volume-add-form{flex-wrap:wrap}}.user-management{display:flex;flex-direction:column;gap:2rem}.user-management-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem;color:var(--text-muted)}.user-management-loading .spinner{animation:spin 1s linear infinite;color:var(--brand)}.user-management-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem 2rem;color:var(--text-dim)}.user-management-empty svg{opacity:.4}.user-management-error{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-lg);color:#dc2626;font-size:.875rem}.user-section{display:flex;flex-direction:column;gap:.75rem}.user-section-title{display:flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding-bottom:.5rem;border-bottom:1px solid var(--border-subtle)}.user-section-title.pending{color:#d97706}.user-section-title.active{color:#16a34a}.user-section-title.suspended{color:#dc2626}.user-list{display:flex;flex-direction:column;gap:.75rem}.user-row{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;padding:1rem 1.25rem;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all .2s ease}.user-row:hover{border-color:var(--brand-light);box-shadow:var(--shadow-sm)}.user-row-info{display:flex;align-items:center;gap:.875rem;flex:1;min-width:200px}.user-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--brand) 0%,var(--accent) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-details{display:flex;flex-direction:column;gap:.125rem;min-width:0}.user-name-row{display:flex;align-items:center;gap:.5rem}.user-name{font-weight:600;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-you-badge{font-size:.75rem;font-weight:600;color:var(--brand)}.user-email{font-size:.8125rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-row-badges{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.user-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;white-space:nowrap}.user-badge.status-active{background:#16a34a1a;color:#16a34a;border:1px solid rgba(22,163,74,.2)}.user-badge.status-pending{background:#f59e0b1a;color:#d97706;border:1px solid rgba(245,158,11,.2)}.user-badge.status-suspended{background:#ef44441a;color:#dc2626;border:1px solid rgba(239,68,68,.2)}.user-badge.role-admin{background:#9333ea1a;color:#9333ea;border:1px solid rgba(147,51,234,.2)}.user-badge.role-user{background:var(--bg-main);color:var(--text-muted);border:1px solid var(--border-subtle)}.user-row-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-left:auto}.user-action-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;border-radius:var(--radius-md);font-family:inherit;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:1px solid transparent;white-space:nowrap}.user-action-btn:disabled{opacity:.5;cursor:not-allowed}.user-action-btn.action-approve{background:#16a34a1a;color:#16a34a;border-color:#16a34a33}.user-action-btn.action-approve:hover:not(:disabled){background:#16a34a33}.user-action-btn.action-suspend{background:#f59e0b1a;color:#d97706;border-color:#f59e0b33}.user-action-btn.action-suspend:hover:not(:disabled){background:#f59e0b33}.user-action-btn.action-admin{background:#9333ea1a;color:#9333ea;border-color:#9333ea33}.user-action-btn.action-admin:hover:not(:disabled){background:#9333ea33}.user-action-btn.action-secondary{background:var(--bg-main);color:var(--text-muted);border-color:var(--border-subtle)}.user-action-btn.action-secondary:hover:not(:disabled){background:var(--border-subtle);color:var(--text-main)}.user-action-btn.action-danger{background:#ef44441a;color:#dc2626;border-color:#ef444433}.user-action-btn.action-danger:hover:not(:disabled){background:#ef444433}@media(max-width:768px){.user-row{flex-direction:column;align-items:flex-start}.user-row-actions{margin-left:0;width:100%}.user-action-btn{flex:1;justify-content:center}}.user-row-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.control-group{display:flex;align-items:center}.inline-select{padding:.5rem 2.5rem .5rem 1rem;border:1px solid var(--border-subtle);border-radius:var(--radius-md);font-size:.875rem;background-color:#fff;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;color:var(--text-main);transition:all .2s ease}.inline-select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(var(--brand-rgb),.1)}.inline-select:disabled{background-color:var(--bg-subtle);cursor:not-allowed;opacity:.7}.library-select{min-width:200px;max-width:300px}.role-select{min-width:120px}.action-text-desktop{display:inline;margin-left:.5rem}.user-row.pending-approval-row{flex-wrap:wrap;gap:1rem;align-items:center}.user-row-info{flex:1;min-width:250px}@media(max-width:768px){.user-row.pending-approval-row{flex-direction:column;align-items:flex-start}.user-row-controls{width:100%;justify-content:space-between;gap:.5rem}.control-group{flex:1}.inline-select{width:100%;min-width:0}.user-row-actions{width:100%;justify-content:flex-end;margin-top:.5rem}.action-text-desktop{display:none}.library-select{max-width:none}}.feedback-admin-page{display:flex;flex-direction:column;gap:1.5rem}.feedback-admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-muted);gap:1rem}.feedback-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}@media(max-width:768px){.feedback-stats-grid{grid-template-columns:repeat(2,1fr)}}.feedback-stat-card{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1rem;display:flex;flex-direction:column;align-items:center;gap:.25rem}.feedback-stat-card .stat-value{font-size:1.75rem;font-weight:800;color:var(--text-main)}.feedback-stat-card .stat-label{font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--text-muted)}.feedback-stat-card.pending .stat-value{color:#94a3b8}.feedback-stat-card.in-progress .stat-value{color:#f59e0b}.feedback-stat-card.resolved .stat-value{color:#22c55e}.feedback-filters{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding:1rem;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.filter-group{display:flex;align-items:center;gap:.75rem;color:var(--text-muted)}.filter-group select{padding:.5rem .75rem;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:.875rem;font-family:inherit;cursor:pointer}.clear-filters-btn{display:flex;align-items:center;gap:.25rem;padding:.5rem .75rem;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:.875rem;color:var(--text-muted);cursor:pointer;transition:all .15s}.clear-filters-btn:hover{background:#ef44441a;border-color:#ef4444;color:#ef4444}.feedback-count{font-size:.875rem;font-weight:600;color:var(--text-muted)}.feedback-admin-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);color:var(--text-muted)}.feedback-admin-empty svg{color:var(--text-dim);margin-bottom:1rem}.feedback-admin-empty h3{font-size:1.25rem;font-weight:700;color:var(--text-main);margin:0 0 .5rem}.feedback-admin-empty p{margin:0}.feedback-admin-list{display:flex;flex-direction:column;gap:.5rem}.feedback-admin-card{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden;transition:all .2s}.feedback-admin-card:hover{border-color:var(--brand-light)}.feedback-admin-card.expanded{border-color:var(--brand)}.feedback-admin-row{display:flex;align-items:center;gap:1rem;padding:1rem;cursor:pointer}.feedback-type-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;flex-shrink:0}.feedback-main-info{flex:1;min-width:0}.feedback-main-info h4{font-size:.95rem;font-weight:700;color:var(--text-main);margin:0 0 .25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.feedback-submitter{font-size:.8rem;color:var(--text-muted)}.feedback-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.feedback-date-small{font-size:.75rem;color:var(--text-dim)}.priority-badge{display:inline-flex;align-items:center;padding:.25rem .5rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;border-radius:4px}.status-select{padding:.375rem .625rem;border:none;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;cursor:pointer;background:#f1f5f9}.expand-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:8px;color:var(--text-muted);cursor:pointer;transition:all .15s}.expand-btn:hover{background:var(--bg-main)}.feedback-details{padding:1rem 1rem 1rem calc(40px + 2rem);border-top:1px solid var(--border-subtle);background:#fafbfc}.feedback-description-full h5{font-size:.75rem;font-weight:700;text-transform:uppercase;color:var(--text-muted);margin:0 0 .5rem}.feedback-description-full p{font-size:.9rem;color:var(--text-main);line-height:1.6;white-space:pre-wrap;margin:0 0 1rem}.feedback-admin-actions{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-top:1rem;border-top:1px solid var(--border-subtle)}.priority-selector{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-muted)}.priority-selector select{padding:.375rem .5rem;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:.875rem}.delete-feedback-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:transparent;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;color:#ef4444;cursor:pointer;transition:all .15s}.delete-feedback-btn:hover{background:#ef44441a;border-color:#ef4444}.archive-toggle-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:.875rem;color:var(--text-muted);cursor:pointer;transition:all .15s}.archive-toggle-btn:hover{background:var(--bg-main);border-color:var(--brand-light)}.archive-toggle-btn.active{background:var(--brand-subtle);border-color:var(--brand);color:var(--brand)}.archive-feedback-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .15s}.archive-feedback-btn:hover{background:var(--brand-subtle);border-color:var(--brand);color:var(--brand)}@media(max-width:640px){.feedback-admin-row{flex-wrap:wrap}.feedback-meta{order:5;width:100%;flex-direction:row;justify-content:space-between;margin-top:.5rem}}.account-container{width:100%;max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.account-card{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.account-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border-subtle);background:#f8fafc;display:flex;align-items:center;gap:.5rem}.account-header h3{font-size:1rem;font-weight:700;color:var(--text-main);margin:0}.account-content{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.account-field-group{display:flex;flex-direction:column;gap:.5rem}.account-label{display:block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.account-readonly-row{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#f8fafc;border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-main);font-weight:500}.account-readonly-badge{margin-left:auto;font-size:.75rem;font-weight:600;background:#e2e8f0;color:var(--text-muted);padding:.25rem .5rem;border-radius:4px}.account-form-row{display:flex;gap:.75rem;align-items:stretch}@media(max-width:640px){.account-form-row{flex-direction:column}}.account-input-wrapper{position:relative;flex-grow:1}.account-input-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-dim);pointer-events:none}.account-input{width:100%;padding:.625rem 1rem .625rem 2.5rem;font-size:.95rem;border:1px solid var(--border-subtle);border-radius:var(--radius-md);outline:none;transition:all .2s}.account-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-subtle)}.account-save-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.5rem;background:var(--brand);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.account-save-btn:hover{background:var(--brand-dark);transform:translateY(-1px)}.account-save-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.account-current-name{margin-top:.75rem;font-size:.875rem;color:var(--text-muted);display:flex;align-items:center;gap:.5rem}.account-current-name strong{color:var(--text-main)}.my-feedback-page{width:100%}.my-feedback-header{margin-bottom:2rem}.my-feedback-header h1{font-size:1.75rem;font-weight:800;color:var(--text-main);margin:0 0 .5rem}.my-feedback-header p{color:var(--text-muted);margin:0}.my-feedback-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-muted);gap:1rem}.my-feedback-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);color:var(--text-muted)}.my-feedback-empty svg{color:var(--text-dim);margin-bottom:1rem}.my-feedback-empty h3{font-size:1.25rem;font-weight:700;color:var(--text-main);margin:0 0 .5rem}.my-feedback-empty p{margin:0;max-width:400px}.my-feedback-list{display:flex;flex-direction:column;gap:1rem}.my-feedback-card{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1.25rem;transition:all .2s}.my-feedback-card:hover{border-color:var(--brand-light);box-shadow:var(--shadow-sm)}.feedback-card-header{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.feedback-type-badge,.feedback-status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:600}.feedback-card-title{font-size:1.1rem;font-weight:700;color:var(--text-main);margin:0 0 .5rem}.feedback-card-description{font-size:.9rem;color:var(--text-muted);margin:0 0 1rem;line-height:1.5;white-space:pre-wrap}.feedback-card-footer{display:flex;flex-wrap:wrap;gap:1rem;font-size:.75rem;color:var(--text-dim)}.feedback-date,.feedback-updated{display:flex;align-items:center;gap:.25rem}.animate-spin{animation:spin 1s linear infinite}.dashboard-page{display:flex;flex-direction:column;gap:2rem}.dashboard-header{display:flex;flex-direction:column;gap:1.5rem}@media(min-width:768px){.dashboard-header{flex-direction:row;align-items:flex-end;justify-content:space-between}}.dashboard-header h1{font-size:1.875rem;font-weight:800;color:var(--color-slate-900);margin:0}.dashboard-subtitle{color:var(--color-slate-500);margin-top:.25rem}.dashboard-stats-grid{display:flex;flex-direction:column;gap:1.5rem}.stat-section{background:#fff;border-radius:16px;padding:1.25rem;box-shadow:0 1px 3px #0000000d;border:1px solid var(--color-slate-200)}.stat-section-title{display:flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-slate-500);margin:0 0 1rem}.stat-cards-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.dashboard-stat-card{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:12px;background:var(--color-slate-50);transition:transform .15s ease,box-shadow .15s ease}.dashboard-stat-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.dashboard-stat-card.highlight{animation:pulse-glow 2s infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 #fb923c66}50%{box-shadow:0 0 0 8px #fb923c00}}.stat-card-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;flex-shrink:0}.stat-card-content{display:flex;flex-direction:column}.stat-card-value{font-size:1.5rem;font-weight:800;line-height:1.1}.stat-card-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--color-slate-500);margin-top:.125rem}.stat-card-brand .stat-card-icon{background:var(--color-brand-light, rgba(var(--brand-rgb), .1));color:var(--color-brand)}.stat-card-brand .stat-card-value{color:var(--color-brand)}.stat-card-green .stat-card-icon{background:#22c55e1a;color:#16a34a}.stat-card-green .stat-card-value{color:#16a34a}.stat-card-blue .stat-card-icon{background:#3b82f61a;color:#2563eb}.stat-card-blue .stat-card-value{color:#2563eb}.stat-card-orange .stat-card-icon{background:#fb923c1a;color:#ea580c}.stat-card-orange .stat-card-value{color:#ea580c}.stat-card-purple .stat-card-icon{background:#9333ea1a;color:#9333ea}.stat-card-purple .stat-card-value{color:#9333ea}.stat-card-slate .stat-card-icon{background:var(--color-slate-100);color:var(--color-slate-600)}.stat-card-slate .stat-card-value{color:var(--color-slate-700)}.multi-volume-panel{background:#fff;border-radius:16px;padding:1.25rem;box-shadow:0 1px 3px #0000000d;border:1px solid var(--color-slate-200)}.multi-volume-panel .panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.multi-volume-panel .panel-header h3{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:700;color:var(--color-slate-800);margin:0}.panel-badge{font-size:.7rem;font-weight:700;padding:.25rem .5rem;background:#9333ea1a;color:#9333ea;border-radius:6px;text-transform:uppercase;letter-spacing:.03em}.volume-books-list{display:flex;flex-direction:column;gap:.5rem}.volume-book-row{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#fff;border:1.5px solid var(--color-slate-100);border-radius:10px;cursor:pointer;transition:all .2s ease}.volume-book-row:hover{border-color:var(--color-slate-200);box-shadow:0 4px 12px #0000000f;transform:translateY(-1px)}.volume-book-row.has-overdue{background:#fb923c0a;border-color:#fb923c40}.volume-book-row.has-overdue:hover{box-shadow:0 4px 12px #fb923c1f}.volume-book-info{display:flex;align-items:baseline;gap:.5rem;flex:1;min-width:150px}.volume-book-title{font-weight:600;color:var(--color-slate-800);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.volume-book-count{font-size:.7rem;font-weight:700;color:var(--color-slate-500);background:var(--color-slate-200);padding:.125rem .375rem;border-radius:4px}.volume-cubes{display:flex;gap:.25rem;flex-wrap:wrap}.volume-cube{display:flex;align-items:center;justify-content:center;width:26px;height:26px;font-size:.7rem;font-weight:700;border-radius:6px;transition:transform .1s ease,box-shadow .1s ease;cursor:default}.volume-cube:hover{transform:scale(1.1);box-shadow:0 2px 8px #00000026;z-index:1}.volume-cube.available{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.volume-cube.loaned{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.volume-cube.overdue{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;animation:pulse-cube 1.5s infinite}@keyframes pulse-cube{0%,to{box-shadow:0 0 #f9731680}50%{box-shadow:0 0 0 4px #f9731600}}.volume-cube.lost{background:var(--color-slate-400);color:#fff}.volume-cube.damaged{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.loan-summary{display:flex;align-items:center;gap:.25rem;font-size:.7rem;font-weight:600;color:var(--color-slate-500);background:var(--color-slate-200);padding:.25rem .5rem;border-radius:4px;white-space:nowrap}.loan-summary.overdue{background:#fb923c26;color:#ea580c}.view-all-btn{display:flex;align-items:center;justify-content:center;gap:.25rem;width:100%;padding:.75rem;margin-top:.5rem;font-size:.8rem;font-weight:600;color:var(--color-brand);background:transparent;border:1px dashed var(--color-slate-300);border-radius:8px;cursor:pointer;transition:background .15s ease,border-color .15s ease}.view-all-btn:hover{background:var(--color-slate-50);border-color:var(--color-brand)}.quick-actions{display:flex;gap:.75rem;flex-wrap:wrap}.quick-action-btn{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.25rem;font-size:.875rem;font-weight:600;color:var(--color-slate-700);background:#fff;border:1px solid var(--color-slate-200);border-radius:10px;cursor:pointer;transition:all .15s ease}.quick-action-btn:hover{background:var(--color-slate-50);border-color:var(--color-brand);color:var(--color-brand)}.mv-controls{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.mv-search-wrapper{position:relative;flex:1;min-width:200px}.mv-search-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);color:var(--color-slate-400);pointer-events:none;transition:color .2s}[dir=rtl] .mv-search-icon{left:auto;right:.875rem}.mv-search-input{width:100%;padding:.625rem .875rem .625rem 2.5rem;background:#fff;border:1.5px solid var(--color-slate-200);border-radius:10px;font-family:inherit;font-size:.85rem;font-weight:500;color:var(--color-slate-800);transition:all .2s;outline:none}[dir=rtl] .mv-search-input{padding:.625rem 2.5rem .625rem .875rem}.mv-search-input::placeholder{color:var(--color-slate-400)}.mv-search-input:hover{border-color:var(--color-slate-300);box-shadow:0 4px 12px #0000000f}.mv-search-input:focus{background:#fff;border-color:var(--color-brand);box-shadow:0 4px 16px #6366f126}.mv-search-wrapper:focus-within .mv-search-icon{color:var(--color-brand)}.mv-sort-wrapper{position:relative}.mv-sort-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:#fff;border:1.5px solid var(--color-slate-200);border-radius:10px;font-family:inherit;font-size:.8rem;font-weight:600;color:var(--color-slate-700);cursor:pointer;transition:all .2s;white-space:nowrap}.mv-sort-btn:hover{border-color:var(--color-slate-300);box-shadow:0 4px 12px #0000000f;transform:translateY(-1px)}.mv-sort-btn svg{opacity:.7}.mv-sort-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:180px;background:#fff;border:1px solid var(--color-slate-200);border-radius:12px;box-shadow:0 10px 40px -10px #0003;padding:.375rem;z-index:50;animation:dropdownFadeIn .15s ease}[dir=rtl] .mv-sort-dropdown{right:auto;left:0}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.mv-sort-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.625rem .875rem;background:transparent;border:none;border-radius:8px;font-family:inherit;font-size:.8rem;font-weight:500;color:var(--color-slate-700);cursor:pointer;transition:background .15s,color .15s;text-align:left}[dir=rtl] .mv-sort-option{text-align:right}.mv-sort-option:hover{background:var(--color-slate-100)}.mv-sort-option.active{background:#6366f11a;color:var(--color-brand);font-weight:600}.mv-sort-option svg{color:var(--color-brand);flex-shrink:0}.mv-results-info{font-size:.75rem;font-weight:600;color:var(--color-slate-500);margin-bottom:.75rem;padding:.375rem .75rem;background:var(--color-slate-50);border-radius:6px;width:fit-content}.mv-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:2rem;color:var(--color-slate-400);text-align:center}.mv-empty-state p{margin:0;font-size:.875rem;font-weight:500}.activity-log-page{padding:0}.activity-filters{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.filter-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--glass-bg);border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .15s ease}.filter-toggle:hover{background:var(--glass-bg-hover);border-color:var(--brand)}.filter-toggle.active{background:var(--brand-subtle);border-color:var(--brand);color:var(--brand)}.filter-toggle svg.rotate{transform:rotate(180deg)}.filter-badge{background:var(--brand);color:#fff;font-size:.7rem;font-weight:600;padding:.1rem .4rem;border-radius:999px;min-width:1.2rem;text-align:center}.clear-filters-btn{padding:.5rem .75rem;background:transparent;border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-muted);font-size:.875rem;cursor:pointer;transition:all .15s ease}.clear-filters-btn:hover{background:var(--glass-bg);color:var(--text-primary)}.activity-count{margin-left:auto;color:var(--text-muted);font-size:.875rem}.filter-panel{display:flex;gap:1rem;padding:1rem;background:var(--glass-bg);border:1px solid var(--border-color);border-radius:.75rem;margin-bottom:1rem;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.375rem;min-width:180px}.filter-group label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.filter-group select{padding:.5rem .75rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-primary);font-size:.875rem;cursor:pointer}.filter-group select:focus{outline:none;border-color:var(--brand)}.activity-list{display:flex;flex-direction:column;gap:1.5rem}.activity-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--text-muted);gap:.75rem}.activity-group{display:flex;flex-direction:column}.activity-date-header{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-subtle);margin-bottom:.75rem}.activity-items{display:flex;flex-direction:column;gap:.5rem}.activity-item{display:flex;gap:.75rem;padding:.75rem 1rem;background:var(--glass-bg);border:1px solid var(--border-color);border-radius:.75rem;transition:all .15s ease}.activity-item:hover{background:var(--glass-bg-hover);border-color:var(--border-hover)}.activity-icon{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:.5rem;flex-shrink:0}.activity-icon.bg-green-100{background:#22c55e26;color:#22c55e}.activity-icon.bg-blue-100{background:#3b82f626;color:#3b82f6}.activity-icon.bg-orange-100{background:#f9731626;color:#f97316}.activity-icon.bg-red-100{background:#ef444426;color:#ef4444}.activity-icon.bg-brand\/10{background:var(--brand-subtle);color:var(--brand)}.activity-icon.bg-slate-100{background:var(--glass-bg);color:var(--text-muted)}.activity-content{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:0}.activity-main{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.activity-action{font-weight:500;color:var(--text-primary);font-size:.9rem;text-transform:capitalize}.activity-entity{display:flex;align-items:center;gap:.25rem;padding:.15rem .5rem;background:var(--brand-subtle);color:var(--brand);border-radius:999px;font-size:.8rem;font-weight:500;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-meta{display:flex;align-items:center;gap:.75rem;font-size:.8rem;color:var(--text-muted)}.activity-user{display:flex;align-items:center;gap:.375rem}.user-avatar-tiny{width:1rem;height:1rem;border-radius:999px;object-fit:cover}.activity-time{color:var(--text-muted)}.activity-details{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.25rem}.detail-tag{display:inline-flex;align-items:center;padding:.2rem .5rem;background:var(--bg-secondary);border-radius:.25rem;font-size:.75rem;color:var(--text-muted)}.activity-log-page .empty-state{padding:3rem;text-align:center}.activity-log-page .empty-state.compact{padding:2rem}.activity-log-page .empty-icon{color:var(--text-muted);opacity:.5;margin-bottom:1rem}.activity-log-page .empty-state h3{color:var(--text-primary);margin-bottom:.5rem}.activity-log-page .empty-state p{color:var(--text-muted);font-size:.9rem}@media(max-width:640px){.filter-panel{flex-direction:column}.filter-group{min-width:100%}.activity-item{padding:.625rem .75rem}.activity-entity{max-width:200px}.activity-meta{flex-direction:column;align-items:flex-start;gap:.25rem}}.library-details-page{padding:2rem 3rem;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.library-details-header{display:flex;flex-direction:column;gap:1rem}.back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-muted);font-weight:600;font-size:.9rem;border:none;background:transparent;cursor:pointer;padding:0;transition:color .2s}.back-link:hover{color:var(--text-main)}.library-title-row{display:flex;align-items:flex-start;justify-content:space-between}.library-title-group h1{font-size:2rem;color:var(--text-main);margin-bottom:.5rem}.library-title-group p{color:var(--text-muted);font-size:1rem}.settings-section{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.settings-section-header{padding:1.5rem;border-bottom:1px solid var(--border-subtle)}.settings-section-header h2{font-size:1.1rem;font-weight:700;color:var(--text-main);display:flex;align-items:center;gap:.75rem;margin:0}.settings-section-content{padding:1.5rem}.settings-form{max-width:600px;display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.875rem;font-weight:600;color:var(--text-main)}.form-input,.form-textarea{width:100%;padding:.75rem 1rem;border:1.5px solid var(--border-subtle);border-radius:var(--radius-md);font-family:inherit;font-size:.95rem;font-weight:500;transition:all .2s;background:#fff;color:var(--text-main)}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-subtle)}.form-textarea{min-height:120px;resize:vertical}.msg-error{padding:.75rem 1rem;background:#fef2f2;color:#dc2626;border-radius:var(--radius-md);font-size:.9rem;display:flex;align-items:center;gap:.5rem;border:1px solid #fee2e2}.msg-success{padding:.75rem 1rem;background:#f0fdf4;color:#16a34a;border-radius:var(--radius-md);font-size:.9rem;display:flex;align-items:center;gap:.5rem;border:1px solid #dcfce7}.danger-section{background:#fef2f2;border:1px solid #fee2e2}.danger-section .settings-section-header h3{color:#991b1b;font-size:1.1rem;font-weight:700;margin:0}.danger-description{color:#b91c1c;font-size:.9rem;margin-bottom:1.5rem}.btn-danger-outline{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#fff;border:1px solid #fcacaa;color:#dc2626;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all .2s}.btn-danger-outline:hover{background:#fef2f2;border-color:#f87171}.danger-confirm-box{background:#fff;padding:1rem;border-radius:var(--radius-md);border:1px solid #fecaca;display:flex;flex-direction:column;gap:1rem;max-width:400px}.danger-confirm-text{font-weight:600;color:#991b1b}.danger-actions{display:flex;gap:.75rem}.btn-danger{background:#dc2626;color:#fff;border:none}.auth-page{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e293b,#0f172a,#1e293b);padding:1.5rem;overflow:hidden}.auth-bg-decor{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}.auth-bg-decor-1{top:-150px;right:-150px;width:400px;height:400px;background:#6366f140}.auth-bg-decor-2{bottom:-150px;left:-150px;width:400px;height:400px;background:#f43f5e33}.auth-bg-decor-amber-1{top:-150px;right:-150px;width:400px;height:400px;background:#f59e0b40}.auth-bg-decor-amber-2{bottom:-150px;left:-150px;width:400px;height:400px;background:#f9731633}.auth-bg-decor-red-1{top:-150px;right:-150px;width:400px;height:400px;background:#ef444440}.auth-bg-decor-red-2{bottom:-150px;left:-150px;width:400px;height:400px;background:#dc262633}.auth-container{width:100%;max-width:420px;position:relative;z-index:1}.auth-brand{text-align:center;margin-bottom:2rem}.auth-logo-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,var(--brand) 0%,var(--accent) 100%);color:#fff;box-shadow:0 20px 40px -10px #6366f180;margin-bottom:1rem}.auth-logo-icon.amber{background:linear-gradient(135deg,#f59e0b,#f97316);box-shadow:0 20px 40px -10px #f59e0b80}.auth-logo-icon.red{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 20px 40px -10px #ef444480}.auth-brand-title{font-size:2rem;font-weight:800;color:#fff;margin-bottom:.5rem;letter-spacing:-.025em}.auth-brand-subtitle{font-size:.9375rem;color:#94a3b8;font-weight:500}.auth-card{background:#ffffff14;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:24px;border:1px solid rgba(255,255,255,.12);padding:2rem;box-shadow:0 25px 50px -12px #00000040}.auth-card-title{font-size:1.5rem;font-weight:700;color:#fff;text-align:center;margin-bottom:1.5rem}.auth-status-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;margin-bottom:1.5rem}.auth-status-icon.pending{background:#f59e0b26;border:2px solid rgba(245,158,11,.4);color:#fbbf24}.auth-status-icon.suspended{background:#ef444426;border:2px solid rgba(239,68,68,.4);color:#f87171}.auth-status-text{color:#cbd5e1;font-size:.9375rem;line-height:1.6;margin-bottom:1.5rem}.auth-email-display{display:flex;align-items:center;justify-content:center;gap:.5rem;color:#94a3b8;font-size:.875rem;margin-bottom:1.5rem}.auth-info-box{padding:1rem;border-radius:12px;margin-bottom:1.5rem;font-size:.875rem;line-height:1.5}.auth-info-box.pending{background:#f59e0b1a;border:1px solid rgba(245,158,11,.25);color:#fde68a}.auth-info-box.suspended{background:#ef44441a;border:1px solid rgba(239,68,68,.25);color:#fecaca}.auth-info-box strong{display:block;margin-bottom:.25rem}.auth-error{padding:1rem;border-radius:12px;background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5;font-size:.875rem;margin-bottom:1.5rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-input-group{position:relative}.auth-input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}[dir=rtl] .auth-input-icon{left:auto;right:1rem}.auth-input{width:100%;padding:.875rem 1rem .875rem 2.75rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:12px;font-family:inherit;font-size:.9375rem;font-weight:500;color:#fff;outline:none;transition:all .2s ease}[dir=rtl] .auth-input{padding:.875rem 2.75rem .875rem 1rem}.auth-input::placeholder{color:#94a3b8b3}.auth-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #6366f140}.auth-submit-btn{display:flex;align-items:center;justify-content:center;gap:.625rem;width:100%;padding:.875rem 1.5rem;margin-top:.5rem;background:linear-gradient(135deg,var(--brand) 0%,var(--accent) 100%);border:none;border-radius:12px;font-family:inherit;font-size:1rem;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease;box-shadow:0 10px 25px -5px #6366f166}.auth-submit-btn:hover{transform:translateY(-2px);box-shadow:0 15px 30px -5px #6366f180}.auth-submit-btn:active{transform:translateY(0)}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-secondary-btn{display:flex;align-items:center;justify-content:center;gap:.625rem;width:100%;padding:.875rem 1.5rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:12px;font-family:inherit;font-size:1rem;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease}.auth-secondary-btn:hover{background:#ffffff26}.auth-spinner{animation:spin 1s linear infinite}.auth-toggle{text-align:center;margin-top:1.5rem}.auth-toggle-btn{background:none;border:none;font-family:inherit;font-size:.9375rem;color:#cbd5e1;cursor:pointer;transition:color .2s}.auth-toggle-btn:hover{color:#fff}.auth-toggle-btn span{color:var(--brand-light);font-weight:600}.auth-footer{text-align:center;color:#64748b;font-size:.8125rem;margin-top:2rem}.auth-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#fff}.auth-loading-spinner{animation:spin 1s linear infinite}.auth-loading-text{font-size:1.125rem;font-weight:500}:root{--brand: #4f46e5;--brand-light: #818cf8;--brand-dark: #3730a3;--brand-subtle: #eef2ff;--accent: #f43f5e;--bg-main: #f1f5f9;--bg-card: rgba(255, 255, 255, .8);--bg-sidebar: rgba(255, 255, 255, .85);--text-main: #0f172a;--text-muted: #64748b;--text-dim: #94a3b8;--border-subtle: rgba(203, 213, 225, .6);--sidebar-width: 280px;--header-height: 72px;--radius-xl: 1.5rem;--radius-lg: 1rem;--radius-md: .75rem;--radius-sm: .5rem;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-blur: 0 8px 32px 0 rgba(31, 38, 135, .07);--font-base: "Plus Jakarta Sans", system-ui, sans-serif;--font-arabic: "Noto Sans Arabic", "Plus Jakarta Sans", system-ui, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-base);background:var(--bg-main);color:var(--text-main);min-height:100vh;line-height:1.6;overflow-x:hidden;display:flex}[dir=rtl] body{font-family:var(--font-arabic)}body.modal-open{overflow:hidden}#root{display:flex;width:100%;height:100vh;overflow:hidden}.app-container{display:flex;width:100%;height:100%}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;height:100%;overflow-y:auto;scroll-behavior:smooth}.p-content{padding:2.5rem 2.5rem 6rem}.sidebar{width:var(--sidebar-width);height:100vh;position:sticky;top:0;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;z-index:50;transition:transform .3s ease}[dir=rtl] .sidebar{border-right:none;border-left:1px solid var(--border-subtle)}.sidebar-header{padding:2rem 1.5rem;display:flex;align-items:center;gap:1rem}.logo-icon{width:42px;height:42px;background:var(--brand);color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 16px -4px #6366f166}.logo-text{font-size:1.25rem;font-weight:800;letter-spacing:-.03em;color:var(--text-main);line-height:1}.logo-subtext{font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;margin-top:4px}.sidebar-search{padding:0 1rem;margin-bottom:1.5rem}.sidebar-search .search-bar-wrapper{max-width:100%}.sidebar-search .search-input{padding:.625rem 1rem .625rem 2.5rem;font-size:.85rem;border-radius:12px}.sidebar-search .search-icon{left:.875rem}[dir=rtl] .sidebar-search .search-icon{left:auto;right:.875rem}[dir=rtl] .sidebar-search .search-input{padding:.625rem 2.5rem .625rem 1rem}.sidebar-lang{padding:0 1rem;margin-bottom:1rem;position:relative}.lang-toggle-sidebar{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:#fff;border:1.5px solid var(--border-subtle);border-radius:14px;font-family:inherit;font-size:.875rem;font-weight:700;color:var(--text-main);cursor:pointer;transition:all .2s}.lang-toggle-sidebar:hover{border-color:var(--brand-light)}.lang-toggle-sidebar.active{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-subtle)}.lang-toggle-sidebar svg:first-child{color:var(--brand)}.lang-label{flex:1;text-align:start}.lang-dropdown-sidebar{position:absolute;bottom:100%;left:1rem;right:1rem;margin-bottom:.5rem;background:#fff;border:1px solid var(--border-subtle);border-radius:14px;box-shadow:0 -10px 40px -10px #00000026;padding:.5rem;z-index:60;display:flex;flex-direction:column;gap:.25rem}.sidebar-signout{padding:0 1rem 1rem;margin-top:auto}.signout-btn{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:#ef44441a;border:1.5px solid rgba(239,68,68,.2);border-radius:14px;font-family:inherit;font-size:.875rem;font-weight:600;color:#dc2626;cursor:pointer;transition:all .2s}.signout-btn:hover{background:#ef444426;border-color:#ef444466;transform:translateY(-1px)}.signout-btn svg{flex-shrink:0}.sidebar-feedback-btn{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;margin-bottom:.5rem;background:var(--brand-subtle);border:1.5px solid var(--brand-light);border-radius:14px;font-family:inherit;font-size:.875rem;font-weight:600;color:var(--brand);cursor:pointer;transition:all .2s}.sidebar-feedback-btn:hover{background:var(--brand);border-color:var(--brand);color:#fff;transform:translateY(-1px)}.sidebar-nav{flex:1;padding:0 1rem;display:flex;flex-direction:column;gap:2rem;overflow-y:auto}.nav-section{display:flex;flex-direction:column;gap:.5rem}.nav-section-title{font-size:.7rem;font-weight:800;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;padding:0 .875rem;margin-bottom:.5rem}.nav-item{display:flex;align-items:center;gap:.875rem;padding:.875rem;border-radius:14px;color:var(--text-muted);font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s;position:relative}.nav-item:hover{background:#fff;color:var(--brand);box-shadow:var(--shadow-sm)}.nav-item.active{background:var(--brand);color:#fff;box-shadow:0 8px 20px -4px #6366f180}.nav-label{flex:1}.active-indicator{width:6px;height:6px;background:#fff;border-radius:50%}.sidebar-footer{padding:1.5rem;border-top:1px solid var(--border-subtle);background:#fff6}.user-profile{display:flex;align-items:center;gap:.875rem;padding:.875rem;background:#fff;border:1px solid var(--border-subtle);border-radius:16px;box-shadow:var(--shadow-sm);transition:transform .2s}.user-profile:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--brand-light)}.avatar{width:40px;height:40px;border-radius:50%;background:var(--bg-main);overflow:hidden;border:2px solid white;box-shadow:0 0 0 1px var(--border-subtle)}.avatar img{width:100%;height:100%;object-fit:cover}.user-info{flex:1;display:flex;flex-direction:column}.user-name{font-size:.9rem;font-weight:800;color:var(--text-main)}.user-role{font-size:.75rem;font-weight:600;color:var(--brand)}.btn-icon-sm{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-dim);background:var(--bg-main);border:none;cursor:pointer;transition:all .2s}.btn-icon-sm:hover{background:var(--brand-light);color:#fff}@media(max-width:1024px){.sidebar{position:fixed;transform:translate(-100%);box-shadow:20px 0 40px #0000001a}[dir=rtl] .sidebar{transform:translate(100%)}}.page-header{position:sticky;top:0;z-index:30;padding:1rem 2rem;background:#ffffffd9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-subtle)}.search-bar-wrapper{position:relative;flex:1;max-width:480px}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-dim);pointer-events:none;transition:color .2s}[dir=rtl] .search-icon{left:auto;right:1rem}.search-bar-wrapper:focus-within .search-icon{color:var(--brand)}.search-input{width:100%;padding:.75rem 1rem .75rem 2.75rem;background:#fff;border:1.5px solid var(--border-subtle);border-radius:14px;font-family:inherit;font-size:.9rem;font-weight:600;color:var(--text-main);transition:all .2s;outline:none}[dir=rtl] .search-input{padding:.75rem 2.75rem .75rem 1rem}.search-input::placeholder{color:var(--text-dim);font-weight:500}.search-input:focus{border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-subtle)}.lang-toggle{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:#fff;border:1.5px solid var(--border-subtle);border-radius:12px;font-family:inherit;font-size:.875rem;font-weight:700;color:var(--text-main);cursor:pointer;transition:all .2s}.lang-toggle:hover{border-color:var(--brand-light)}.lang-toggle.active{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-subtle)}.lang-toggle svg:first-child{color:var(--brand)}.lang-text{display:none}@media(min-width:640px){.lang-text{display:inline}}.chevron{color:var(--text-dim);transition:transform .2s}.lang-toggle .chevron.rotate-180{transform:rotate(180deg)}.lang-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;width:180px;background:#fff;border:1px solid var(--border-subtle);border-radius:16px;box-shadow:0 10px 40px -10px #0003;padding:.5rem;z-index:60;display:flex;flex-direction:column;gap:.25rem}[dir=rtl] .lang-dropdown{right:auto;left:0}.lang-option{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-radius:12px;border:none;background:transparent;font-family:inherit;font-size:.9rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .15s;text-align:start;width:100%}.lang-option:hover{background:var(--bg-main);color:var(--text-main)}.lang-option.active{background:var(--brand-subtle);color:var(--brand)}.active-dot{width:6px;height:6px;border-radius:50%;background:var(--brand)}h1,h2,h3,h4{font-weight:800;letter-spacing:-.02em;line-height:1.2}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.625rem;padding:.75rem 1.25rem;border-radius:var(--radius-md);font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);border:1px solid transparent;white-space:nowrap}.btn-primary{background:var(--brand);color:#fff;box-shadow:0 4px 14px #6366f163}.btn-primary:hover{background:var(--brand-dark);transform:translateY(-2px);box-shadow:0 6px 20px #6366f173}.btn-secondary{background:#fff;border:1px solid var(--border-subtle);color:var(--text-main);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--bg-main);border-color:var(--brand-light);color:var(--brand)}.btn-add-alternate{width:100%;padding:.625rem 1rem;border:2px dashed var(--border-subtle);border-radius:var(--radius-lg);background:transparent;color:var(--text-muted);font-size:.875rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;transition:all .2s ease}.btn-add-alternate:hover{border-color:var(--brand);color:var(--brand);background:#6366f10d}:root{--text-secondary: #64748b;--bg-primary: #f8fafc;--bg-card: #ffffff;--border-color: #e2e8f0;--arabic-font: "Amiri", serif;--rtl-font: "Noto Sans Arabic", sans-serif}.rtl-text{direction:rtl;text-align:right;font-family:var(--arabic-font)}.rtl-input{direction:rtl;text-align:right;font-family:var(--rtl-font)}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;max-height:200px;overflow-y:auto;margin-top:4px}.autocomplete-option{padding:.625rem 1rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between;font-size:.875rem;color:var(--text-main);transition:background .15s ease}.autocomplete-option:hover{background:var(--bg-main)}.autocomplete-option.selected{background:var(--brand-subtle);color:var(--brand)}.autocomplete-save-prompt{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;padding:.75rem 1rem;margin-top:4px;display:flex;align-items:center;justify-content:space-between;gap:.75rem;font-size:.875rem;color:var(--text-muted)}.autocomplete-save-actions{display:flex;align-items:center;gap:.5rem}.autocomplete-save-btn{display:flex;align-items:center;gap:.25rem;padding:.375rem .75rem;background:var(--brand);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease}.autocomplete-save-btn:hover{background:var(--brand-dark)}.autocomplete-dismiss-btn{padding:.375rem;background:transparent;color:var(--text-muted);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.autocomplete-dismiss-btn:hover{background:var(--bg-main);color:var(--text-main)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{background:var(--brand-subtle);color:var(--brand)}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}@media(min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}.spec-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.spec-item{background:#f8fafc;padding:1rem;border-radius:12px;border:1px solid #e2e8f0}.spec-label{display:block;font-size:.7rem;font-weight:800;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.spec-value{font-weight:700;color:#1e293b;font-size:.95rem}.volume-list{display:flex;flex-direction:column;gap:.75rem}.volume-card{background:#fff;border:1px solid var(--border-subtle);border-radius:8px;padding:.75rem;transition:all .2s ease}.volume-card:hover{border-color:var(--brand-light);box-shadow:var(--shadow-sm)}.volume-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-subtle)}.volume-number{font-weight:700;color:var(--text-main);font-size:.8rem}.volume-status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .4rem;border-radius:9999px;font-size:.6rem;font-weight:700;text-transform:capitalize}.volume-card-details{display:flex;flex-direction:column;gap:.4rem;font-size:.75rem;color:var(--text-muted)}.volume-detail{display:flex;align-items:center;gap:.3rem}.volume-notes{width:100%;margin-top:.4rem;padding-top:.4rem;border-top:1px dashed var(--border-subtle);font-size:.7rem;color:var(--text-dim);font-style:italic;line-height:1.3}.form-section-header-collapsible{display:flex;align-items:center;gap:.75rem;padding:1rem 0;border-bottom:1px solid var(--border-subtle);margin-bottom:1.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s}.form-section-header-collapsible:hover{color:var(--brand)}.collapsible-indicator{margin-left:auto;transition:transform .3s ease}.collapsible-indicator.open{transform:rotate(180deg)}.form-grid-3{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.form-grid-4{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.truncate-2-lines{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-clamp:2;overflow:hidden}.custom-scrollbar::-webkit-scrollbar{width:6px}.custom-scrollbar::-webkit-scrollbar-thumb{background:var(--text-dim);border-radius:10px}.input-group{display:flex;flex-direction:column;gap:.5rem}.label{font-size:.875rem;font-weight:600;color:var(--text-muted)}.glass-input{background:#fff;border:1.5px solid var(--border-subtle);padding:.875rem 1rem;border-radius:var(--radius-md);width:100%;font-family:inherit;font-size:.9375rem;transition:all .2s;color:var(--text-main);outline:none}.glass-input:focus{border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-subtle)}.bento-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;padding:1.5rem}.card{background:var(--bg-card);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:1.5rem;transition:all .3s cubic-bezier(.175,.885,.32,1.275);position:relative;overflow:hidden}.card:hover{transform:translateY(-8px) scale(1.01);box-shadow:var(--shadow-blur);border-color:var(--brand-light)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;background:#fff;border-radius:var(--radius-xl);border:2px dashed var(--border-subtle);color:var(--text-muted);margin:2rem}.container-full{max-width:1440px;width:100%;margin:0 auto}.p-content{padding:2.5rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}@keyframes slideInUp{0%{opacity:0;transform:translateY(2rem)}to{opacity:1;transform:translateY(0)}}.animate-up{animation:slideInUp .4s cubic-bezier(.16,1,.3,1) forwards}.ms-auto{margin-inline-start:auto}.me-2{margin-inline-end:.5rem}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-dim);border-radius:10px;border:2px solid var(--bg-main)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.modal-overlay{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:1.5rem;background:#0f172aa6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);overflow-y:auto}.modal-container{background:#fff;width:100%;max-width:720px;border-radius:var(--radius-xl);box-shadow:0 25px 50px -12px #00000040;border:1px solid var(--border-subtle);display:flex;flex-direction:column;animation:slideInUp .35s cubic-bezier(.16,1,.3,1) forwards;margin:auto}.modal-header{display:flex;align-items:center;gap:1rem;padding:1.5rem 2rem;border-bottom:1px solid var(--border-subtle);background:var(--brand-subtle)}.modal-header-icon{width:48px;height:48px;background:var(--brand);color:#fff;border-radius:14px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 16px -4px #4f46e566}.modal-title{font-size:1.25rem;font-weight:800;color:var(--text-main);line-height:1.2}.modal-subtitle{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:2px}.modal-close-btn{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--border-subtle);color:var(--text-muted);cursor:pointer;transition:all .2s}.modal-close-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}.modal-body{padding:2rem;overflow-y:auto;max-height:60vh}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.25rem 2rem;border-top:1px solid var(--border-subtle);background:var(--bg-main)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}@media(max-width:640px){.form-grid{grid-template-columns:1fr}}.form-column{display:flex;flex-direction:column;gap:1.25rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group.flex-grow{flex:1}.form-label{font-size:.7rem;font-weight:800;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;padding-inline-start:.25rem}.input-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;align-items:start}.input-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;align-items:start}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.input-icon{position:absolute;left:1rem;color:var(--text-dim);pointer-events:none;transition:color .2s}[dir=rtl] .input-icon{left:auto;right:1rem}.input-wrapper:focus-within .input-icon{color:var(--brand)}.form-input{width:100%;padding:.875rem 1rem;border:1.5px solid var(--border-subtle);border-radius:var(--radius-md);font-family:inherit;font-size:.9375rem;font-weight:600;color:var(--text-main);background:#fff;transition:all .2s;outline:none}.form-input::placeholder{color:var(--text-dim);font-weight:500}.form-input:focus{border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-subtle)}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}[dir=rtl] .form-select{background-position:left 1rem center;padding-right:2.75rem;padding-left:2.5rem}.form-textarea{min-height:100px;resize:none;padding-inline-start:1rem;line-height:1.6}.form-input-sm{padding:.625rem .875rem;font-size:.85rem}.contained-work-entry{position:relative;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:.875rem 1rem;padding-inline-start:2.25rem;margin-bottom:.75rem;transition:all .2s ease}.contained-work-entry:hover{border-color:var(--brand-light);box-shadow:var(--shadow-sm)}.contained-work-entry:hover .contained-work-remove{opacity:1}.contained-work-remove{position:absolute;top:50%;left:.625rem;transform:translateY(-50%);width:20px;height:20px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:50%;color:var(--text-dim);cursor:pointer;opacity:.5;transition:all .2s ease}[dir=rtl] .contained-work-remove{left:auto;right:.625rem}[dir=rtl] .contained-work-entry{padding-inline-start:1rem;padding-inline-end:2.25rem}.contained-work-remove:hover{background:var(--accent);color:#fff;opacity:1}.contained-work-fields{display:grid;grid-template-columns:2fr 1.5fr 80px 1fr 1fr;gap:.75rem;align-items:end}.contained-work-fields .form-group{min-width:0}.contained-work-fields .form-label{font-size:.625rem;margin-bottom:.25rem}@media(max-width:900px){.contained-work-fields{grid-template-columns:1fr 1fr}.contained-work-death{grid-column:span 2}.contained-work-subject,.contained-work-role{grid-column:span 1}}@media(max-width:600px){.contained-work-fields{grid-template-columns:1fr}.contained-work-fields>*{grid-column:span 1!important}}.settings-page{max-width:800px}.settings-header{display:flex;align-items:center;gap:1.25rem;margin-bottom:2.5rem}.settings-header-icon{width:56px;height:56px;background:var(--brand);color:#fff;border-radius:16px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px -4px #4f46e566}.settings-title{font-size:1.75rem;font-weight:800;color:var(--text-main)}.settings-subtitle{font-size:.875rem;font-weight:600;color:var(--text-muted);margin-top:2px}.settings-section{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:2rem;margin-bottom:1.5rem}.section-title{font-size:1rem;font-weight:800;color:var(--text-main);display:flex;align-items:center;gap:.625rem;margin-bottom:.5rem}.section-description{font-size:.875rem;color:var(--text-muted);margin-bottom:1.5rem}.add-field-form{display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end;margin-bottom:1.5rem}.add-field-form .flex-grow{flex:1;min-width:200px}.type-select{width:140px;padding-inline-start:1rem}.custom-fields-list{display:flex;flex-direction:column;gap:.75rem}.custom-field-item{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--bg-main);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:all .2s}.custom-field-item:hover{border-color:var(--brand-light);box-shadow:var(--shadow-sm)}.field-info{display:flex;align-items:center;gap:.75rem}.field-name{font-weight:700;color:var(--text-main)}.field-type{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;padding:.25rem .625rem;background:var(--brand-subtle);color:var(--brand);border-radius:6px}.delete-btn{color:var(--text-dim)}.delete-btn:hover{background:#fef2f2;color:var(--accent)}.empty-fields{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;color:var(--text-dim);text-align:center;border:2px dashed var(--border-subtle);border-radius:var(--radius-lg)}.empty-icon{margin-bottom:.75rem;opacity:.5}.custom-fields-section{margin-top:2rem;padding-top:1.5rem;border-top:1px dashed var(--border-subtle)}.custom-fields-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:800;color:var(--text-muted);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em}.custom-fields-title svg{color:var(--brand)}.custom-fields-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.custom-field-input{padding-inline-start:1rem}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-top:1.5rem;margin-bottom:1.5rem}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.stats-grid{grid-template-columns:1fr}}.stat-card{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all .2s}.stat-card:hover{border-color:var(--brand-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-content{display:flex;flex-direction:column;min-width:0}.stat-label{font-size:.7rem;font-weight:800;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.25rem}.stat-value-row{display:flex;align-items:baseline;gap:.375rem}.stat-value{font-size:1.75rem;font-weight:800;line-height:1}.stat-suffix{font-size:.8rem;font-weight:600;color:var(--text-muted)}.view-controls-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:.875rem 1.25rem;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.controls-left{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.book-count{font-size:.875rem;font-weight:700;color:var(--text-muted);white-space:nowrap}.filters-group{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.filters-icon{color:var(--text-dim)}.filter-select{appearance:none;padding:.5rem 1.75rem .5rem .75rem;font-family:inherit;font-size:.8rem;font-weight:600;color:var(--text-main);background:var(--bg-main);border:1px solid var(--border-subtle);border-radius:8px;cursor:pointer;transition:all .15s;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center;max-width:150px}.filter-select:focus{outline:none;border-color:var(--brand);background-color:#fff}.clear-filters-btn{display:flex;align-items:center;gap:.25rem;padding:.5rem .75rem;font-family:inherit;font-size:.75rem;font-weight:700;color:var(--accent);background:#f43f5e1a;border:none;border-radius:6px;cursor:pointer;transition:all .15s}.clear-filters-btn:hover{background:var(--accent);color:#fff}.view-toggle-buttons{display:flex;gap:.25rem;padding:.25rem;background:var(--bg-main);border-radius:10px}.view-toggle-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:var(--text-dim);border-radius:8px;cursor:pointer;transition:all .15s}.view-toggle-btn:hover{color:var(--text-main);background:#fff}.view-toggle-btn.active{background:var(--brand);color:#fff;box-shadow:0 4px 12px -2px #4f46e566}.book-list-view{display:flex;flex-direction:column;gap:.75rem}.book-list-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:all .2s}.book-list-item:hover{border-color:var(--brand-light);box-shadow:var(--shadow-sm)}.book-list-cover{width:48px;height:64px;border-radius:8px;background:var(--brand-subtle);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.book-list-cover img{width:100%;height:100%;object-fit:cover}.book-list-cover span{font-size:1.25rem;font-weight:800;color:var(--brand);opacity:.5}.book-list-info{flex:1;min-width:0}.book-list-title{font-size:1rem;font-weight:800;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-list-author{font-size:.875rem;font-weight:600;color:var(--brand)}.book-list-meta{display:flex;gap:.5rem;flex-shrink:0}.book-list-isbn{font-size:.8rem;font-weight:600;font-family:monospace;color:var(--text-dim);width:140px;text-align:end}@media(max-width:768px){.book-list-item{flex-wrap:wrap}.book-list-meta,.book-list-isbn{display:none}}.book-table-wrapper{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden}.book-table{width:100%;border-collapse:collapse}.book-table th{text-align:start;padding:1rem 1.25rem;font-size:.7rem;font-weight:800;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;background:var(--bg-main);border-bottom:1px solid var(--border-subtle)}.book-table td{padding:1rem 1.25rem;border-bottom:1px solid var(--border-subtle);font-size:.9rem}.book-table tbody tr:last-child td{border-bottom:none}.book-table tbody tr:hover{background:var(--brand-subtle)}.book-table tbody tr:hover td:first-child{color:var(--brand)}.book-table tbody tr.selected{background:#6366f11a}.bulk-actions-bar{display:flex;align-items:center;gap:1rem;padding:.875rem 1.25rem;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-dark) 100%);border-radius:var(--radius-lg);margin-bottom:1rem;color:#fff;box-shadow:0 4px 14px #6366f163}.bulk-count{font-weight:700;font-size:.9rem}.bulk-actions{display:flex;align-items:center;gap:.5rem;flex:1}.bulk-actions-bar .btn-icon-sm{background:#fff3;color:#fff}.bulk-actions-bar .btn-icon-sm:hover{background:#ffffff4d}.checkbox-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:var(--text-dim);cursor:pointer;border-radius:6px;transition:all .15s ease}.checkbox-btn:hover{background:var(--brand-subtle);color:var(--brand)}.btn-danger:hover{background:#b91c1c}.btn-danger:disabled{background:#f87171;cursor:not-allowed;opacity:.7}.btn-danger-subtle{background:#dc26261a;color:#dc2626;border:1.5px solid rgba(220,38,38,.3)}.btn-danger-subtle:hover{background:#dc262633;border-color:#dc2626}.bg-red-100{background-color:#fee2e2!important}.text-red-600{color:#dc2626!important}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.sortable-header:hover{color:var(--brand)}.sortable-header span{display:inline-flex;align-items:center;gap:.375rem}.sort-icon{opacity:.3;transition:opacity .15s,color .15s}.sort-icon.active{opacity:1;color:var(--brand)}.filter-dropdown{position:relative;display:flex;align-items:center}.filter-icon{position:absolute;left:.75rem;color:var(--text-dim);pointer-events:none}.filter-select{appearance:none;padding:.5rem 2rem;font-family:inherit;font-size:.8rem;font-weight:600;color:var(--text-main);background:#fff;border:1px solid var(--border-subtle);border-radius:8px;cursor:pointer;transition:all .15s;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center}.filter-select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-subtle)}.filter-clear{position:absolute;right:1.75rem;display:flex;align-items:center;justify-content:center;width:16px;height:16px;background:var(--text-dim);color:#fff;border:none;border-radius:50%;cursor:pointer;transition:background .15s}.filter-clear:hover{background:var(--accent)}.table-actions{display:flex;gap:.25rem}.table-row-clickable{cursor:pointer}.book-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1)}.book-card:hover{border-color:var(--brand-light);box-shadow:0 12px 40px -12px #4f46e540;transform:translateY(-4px)}.book-card-cover{height:180px;background:linear-gradient(135deg,var(--brand-subtle),rgba(99,102,241,.1));display:flex;align-items:center;justify-content:center;overflow:hidden}.book-card-cover img{width:100%;height:100%;object-fit:cover;transition:transform .4s}.book-card:hover .book-card-cover img{transform:scale(1.05)}.cover-letter{font-size:4rem;font-weight:800;color:var(--brand);opacity:.2;text-transform:uppercase}.book-card-content{padding:1.25rem;flex:1}.book-card-title{font-size:1.1rem;font-weight:800;color:var(--text-main);line-height:1.3;margin-bottom:.375rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-card-author{font-size:.875rem;font-weight:700;color:var(--brand);margin-bottom:.75rem}.book-card-badges{display:flex;flex-wrap:wrap;gap:.375rem}.book-card-footer{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;border-top:1px solid var(--border-subtle);background:var(--bg-main)}.book-card-isbn{font-size:.7rem;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em}.book-card-delete{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-dim);border-radius:8px;cursor:pointer;transition:all .15s}.book-card-delete:hover{background:#f43f5e1a;color:var(--accent)}.book-details{max-width:900px}.back-button{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;font-family:inherit;font-size:.875rem;font-weight:700;color:var(--text-muted);background:#fff;border:1px solid var(--border-subtle);border-radius:10px;cursor:pointer;transition:all .15s;margin-bottom:2rem}.back-button:hover{color:var(--brand);border-color:var(--brand-light)}.book-details-header{display:flex;gap:2rem;margin-bottom:2.5rem}.book-details-cover{width:200px;height:280px;flex-shrink:0;border-radius:16px;overflow:hidden;background:var(--brand-subtle);border:1px solid var(--border-subtle)}.book-details-cover img{width:100%;height:100%;object-fit:cover}.cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--brand);opacity:.3}.book-details-info{flex:1;display:flex;flex-direction:column}.book-title{font-size:2rem;font-weight:800;color:var(--text-main);line-height:1.2;margin-bottom:.5rem}.book-author{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:700;color:var(--brand);margin-bottom:1.5rem}.book-meta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2rem}.meta-badge{display:flex;align-items:center;gap:.625rem;padding:.75rem 1rem;background:#fff;border:1px solid var(--border-subtle);border-radius:12px}.meta-badge svg{color:var(--brand)}.meta-text{display:flex;flex-direction:column}.meta-label{font-size:.65rem;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em}.meta-value{font-size:.9rem;font-weight:700;color:var(--text-main)}.book-actions{display:flex;gap:.75rem;margin-top:auto}.btn-danger{background:#f43f5e1a;color:var(--accent);border:1px solid transparent}.btn-danger:hover{background:var(--accent);color:#fff}.book-section{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1.5rem 2rem;margin-bottom:1.5rem}.section-heading{font-size:.75rem;font-weight:800;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem}.book-description{font-size:1rem;line-height:1.7;color:var(--text-muted)}.custom-data-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.custom-data-item{display:flex;flex-direction:column;gap:.25rem}.custom-data-label{font-size:.7rem;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em}.custom-data-value{font-size:.95rem;font-weight:600;color:var(--text-main)}@media(max-width:768px){.book-details-header{flex-direction:column;align-items:center;text-align:center}.book-details-cover{width:160px;height:220px}.book-meta,.book-actions{justify-content:center}}.filter-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.filter-modal{background:#fff;width:100%;max-width:100%;height:100%;border-radius:0;box-shadow:none;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}@media(min-width:640px){.filter-modal{max-width:600px;height:auto;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a}}.filter-modal{width:100%;max-width:none;border-radius:0;height:100%}.filter-modal{background:#fff;width:100%;max-width:100%;height:auto;min-height:50vh;position:absolute;bottom:0;border-radius:20px 20px 0 0;animation:slideUp .3s ease-out}@media(min-width:768px){.filter-modal{position:relative;width:90%;max-width:800px;bottom:auto;border-radius:16px;min-height:auto;animation:scaleIn .2s cubic-bezier(.16,1,.3,1)}}.filter-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-subtle)}.filter-modal-header h3{font-size:1.125rem;font-weight:700;color:var(--text-main);margin:0}.close-modal-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:6px;transition:all .15s}.close-modal-btn:hover{background:var(--bg-main);color:var(--text-main)}.filter-modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.filter-section{display:flex;flex-direction:column;gap:.5rem}.filter-section label{font-size:.875rem;font-weight:600;color:var(--text-dim)}.filter-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;background:var(--bg-main);border-top:1px solid var(--border-subtle)}.filter-grid-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}@media(max-width:640px){.filter-grid-row{grid-template-columns:1fr}}.filter-input{width:100%;padding:.6rem 1rem;font-family:inherit;font-size:.9rem;color:var(--text-main);background:#fff;border:1px solid var(--border-subtle);border-radius:8px;transition:all .15s}.sort-control-wrapper{position:relative;display:flex;align-items:center;gap:.25rem;background:#fff;border:1px solid var(--border-subtle);border-radius:12px;padding:.2rem .2rem .2rem .8rem;height:40px;box-shadow:0 1px 2px #00000008;transition:all .2s ease}.sort-control-wrapper:hover{border-color:var(--brand-light);box-shadow:0 2px 5px #0000000d}.sort-trigger{display:flex;align-items:center;cursor:pointer;height:100%;padding-right:.5rem;border-right:1px solid var(--border-subtle)}.sort-direction-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;background:transparent;color:var(--text-dim);border-radius:8px;cursor:pointer;transition:all .15s}.sort-direction-btn:hover{background:var(--bg-main);color:var(--brand)}.sort-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:#fff;border:1px solid var(--border-subtle);border-radius:16px;box-shadow:0 10px 30px -5px #0000001f;min-width:180px;padding:.5rem;z-index:50;animation:scaleIn .15s ease-out}.sort-option{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1rem;border-radius:10px;font-size:.9rem;font-weight:500;color:var(--text-main);cursor:pointer;transition:all .1s}.sort-option:hover{background:var(--bg-main);color:var(--brand)}.sort-option.selected{background:var(--brand-subtle);color:var(--brand);font-weight:600}.btn-filter{display:flex;align-items:center;gap:.6rem;padding:0 1.25rem;height:40px;background:#fff;border:1px solid var(--border-subtle);border-radius:12px;font-size:.9rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #00000008;position:relative}.btn-filter:hover{border-color:var(--brand-light);color:var(--brand-dark);box-shadow:0 2px 5px #0000000d;transform:translateY(-1px)}.btn-filter.active{background:var(--brand-subtle);color:var(--brand);border-color:var(--brand-light);box-shadow:0 0 0 2px var(--brand-subtle-2, rgba(99, 102, 241, .1))}.filter-badge{position:absolute;top:-2px;right:-2px;width:8px;height:8px;background:var(--brand);border-radius:50%;border:2px solid white}.circulation-container{display:flex;flex-direction:column;gap:1.5rem;margin-top:-2rem}.circulation-hero{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-dark) 100%);color:#fff;padding:2.5rem 1.5rem 3.5rem;margin:-2rem -1.5rem 0;position:relative;overflow:hidden;border-bottom-left-radius:28px;border-bottom-right-radius:28px}.circulation-hero:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 10% 20%,rgba(255,255,255,.1) 0%,transparent 20%),radial-gradient(circle at 90% 80%,rgba(255,255,255,.1) 0%,transparent 20%);pointer-events:none}.circulation-hero h2{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.25rem}.circulation-hero p{opacity:.9;font-size:.875rem;font-weight:500}.circulation-stats-bento{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;z-index:10}.stat-bento-card{background:#fff;border-radius:16px;padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 15px -3px #0000000a;border:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s ease}.stat-bento-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px -5px #00000014}.stat-bento-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.25rem}.stat-bento-card.orange .stat-bento-icon{background:#fff7ed;color:#f97316}.stat-bento-card.green .stat-bento-icon{background:#f0fdf4;color:#22c55e}.stat-bento-value{font-size:1.5rem;font-weight:700;line-height:1;color:var(--text-main)}.stat-bento-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:.125rem}.loans-section{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 2px 12px #00000008;border:1px solid var(--border-subtle)}.loans-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.loans-title{font-size:1.5rem;font-weight:800;color:var(--text-main);display:flex;align-items:center;gap:.75rem}.glass-table{width:100%;border-collapse:separate;border-spacing:0 .75rem}.glass-table th{padding:1rem 1.5rem;font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;border:none}.loan-row{background:#fff;transition:all .2s;border-radius:16px;box-shadow:0 2px 4px #00000005;border:1px solid transparent}.loan-row:hover{background:var(--bg-main);box-shadow:0 4px 12px #0000000a;transform:scale(1.005)}.loan-row td{padding:1.25rem 1.5rem;border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle)}.loan-row td:first-child{border-left:1px solid var(--border-subtle);border-top-left-radius:16px;border-bottom-left-radius:16px}.loan-row td:last-child{border-right:1px solid var(--border-subtle);border-top-right-radius:16px;border-bottom-right-radius:16px}.borrower-avatar{width:36px;height:36px;border-radius:50%;border:2px solid white;box-shadow:0 2px 5px #0000001a}.due-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .8rem;border-radius:99px;font-size:.85rem;font-weight:600}.due-badge.overdue{background:#fef2f2;color:#ef4444}.due-badge.upcoming{background:#fffbeb;color:#f59e0b}.due-badge.safe{background:#f0fdf4;color:#22c55e}.return-btn-premium{padding:.6rem 1.2rem;background:#fff;border:1px solid var(--border-subtle);border-radius:12px;font-size:.85rem;font-weight:700;color:var(--text-main);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.return-btn-premium:hover{background:var(--brand);border-color:var(--brand);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #6366f133}.empty-loan-state{padding:4rem 2rem;text-align:center;background:var(--bg-main);border-radius:24px;border:2px dashed var(--border-subtle)}.empty-loan-icon{width:80px;height:80px;margin:0 auto 1.5rem;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--brand);box-shadow:0 4px 10px #0000000d}@keyframes slideInUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.animate-up{animation:slideInUp .4s ease-out forwards}.searchable-select{position:relative}.select-trigger{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#fff;border:1px solid var(--border-subtle);border-radius:10px;cursor:pointer;font-size:.95rem;color:var(--text-main);transition:all .15s}.select-trigger:hover{border-color:var(--border-focus)}.select-trigger.open{border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-subtle)}.select-dropdown{position:absolute;top:100%;left:0;width:100%;margin-top:.5rem;background:#fff;border:1px solid var(--border-subtle);border-radius:10px;box-shadow:0 10px 15px -3px #0000001a;z-index:50;overflow:hidden;animation:fadeIn .15s ease-out}.select-search{padding:.75rem;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:.5rem;color:var(--text-muted)}.select-search input{border:none;outline:none;width:100%;font-size:.9rem;color:var(--text-main)}.select-options{max-height:200px;overflow-y:auto;padding:.5rem 0}.select-option{display:flex;align-items:center;justify-content:space-between;padding:.625rem 1rem;cursor:pointer;font-size:.9rem;color:var(--text-main)}.select-option:hover{background:var(--bg-main)}.select-option.selected{background:var(--brand-subtle);color:var(--brand);font-weight:600}.no-options{padding:.75rem 1rem;font-size:.875rem;color:var(--text-muted);text-align:center}.modal-container{background:#fff;width:95%;max-width:900px;max-height:90vh;border-radius:24px;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;overflow:hidden;animation:scaleIn .2s cubic-bezier(.16,1,.3,1)}.modal-body-split{display:flex;flex:1;overflow:hidden;min-height:0}.form-panel{flex:3;padding:2rem;overflow-y:auto;min-width:0}.preview-panel{flex:2;background:var(--bg-main);padding:2rem;border-left:1px solid var(--border-subtle);display:flex;flex-direction:column;align-items:center;justify-content:center;overflow-y:auto}@media(max-width:768px){.modal-body-split{flex-direction:column-reverse}.preview-panel{display:none}.form-panel{padding:1.5rem}}.preview-card-wrapper{perspective:1000px;transform-style:preserve-3d;width:100%;max-width:280px}.preview-label{text-transform:uppercase;letter-spacing:.1em;font-size:.75rem;font-weight:800;color:var(--text-dim);margin-bottom:1rem;text-align:center}.form-section{margin-bottom:2rem}.form-section-header{margin-bottom:1.25rem;display:flex;align-items:center;gap:.5rem;padding-bottom:.5rem;border-bottom:2px solid var(--bg-main)}.section-icon{color:var(--brand)}.section-title{font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.jumbo-input{font-size:1.25rem;font-weight:700;padding:1rem 1.25rem;border:2px solid var(--border-subtle);border-radius:12px;transition:all .2s}.jumbo-input:focus{border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-subtle)}.input-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media(max-width:640px){.input-grid-3{grid-template-columns:1fr}}.details-hero{height:300px;background:linear-gradient(135deg,var(--brand),var(--brand-dark));position:relative;overflow:hidden;margin:-2rem -2rem 0;border-radius:0 0 50% 10%/0 0 20px 20px}.details-hero:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 18c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm48 25c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm-43-7c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm63 31c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM34 90c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm56-76c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM12 86c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm28-65c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm23-11c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-6 60c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm29 22c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zM32 63c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm57-13c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-9-21c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM60 91c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM35 41c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM12 60c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2z' fill='%23ffffff' fill-opacity='0.05' fill-rule='evenodd'/%3E%3C/svg%3E")}.details-wrapper{max-width:1000px;margin:-180px auto 0;padding:0 1.5rem 3rem;position:relative;z-index:10;animation:slideUp .4s cubic-bezier(.16,1,.3,1)}.details-card{background:#fff;border-radius:20px;box-shadow:0 20px 40px -12px #00000026;display:grid;grid-template-columns:320px 1fr;overflow:hidden}.details-sidebar{padding:2.5rem;background:#fdfdfd;border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;align-items:center}.details-cover-large{width:100%;aspect-ratio:2/3;border-radius:12px;box-shadow:0 15px 30px -5px #0003;overflow:hidden;margin-bottom:2rem;background:var(--bg-main);display:flex;align-items:center;justify-content:center}.details-cover-large img{width:100%;height:100%;object-fit:cover}.details-actions-stack{display:flex;flex-direction:column;gap:.75rem;width:100%}.btn-full{justify-content:center;width:100%}.details-main{padding:3rem}.details-title-large{font-size:2.5rem;font-weight:800;color:var(--text-main);line-height:1.1;margin-bottom:.5rem}.details-author-large{font-size:1.25rem;color:var(--brand);font-weight:600;margin-bottom:2rem;display:flex;align-items:center;gap:.5rem}.stats-row{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:1px solid var(--border-subtle)}.stat-badge-lg{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-main);border-radius:10px;border:1px solid var(--border-subtle)}.stat-badge-lg svg{color:var(--text-muted)}.stat-info{display:flex;flex-direction:column}.stat-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;font-weight:800;color:var(--text-dim)}.stat-value-lg{font-size:.95rem;font-weight:700;color:var(--text-main)}.details-section-title{font-size:1rem;font-weight:700;color:var(--text-main);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.description-text{font-size:1.05rem;line-height:1.7;color:var(--text-muted);max-width:65ch;margin-bottom:3rem}.custom-data-grid-lg{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem}.back-nav-abs{position:absolute;top:2rem;left:2rem;z-index:20}.btn-white-glass{background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;border:1px solid rgba(255,255,255,.3)}.btn-white-glass:hover{background:#ffffff4d;color:#fff}@media(max-width:900px){.details-card{grid-template-columns:1fr;max-width:500px;margin-left:auto;margin-right:auto}.details-sidebar{padding:2rem;border-right:none;border-bottom:1px solid var(--border-subtle)}.details-cover-large{width:180px}.details-main{padding:2rem}.details-title-large{font-size:2rem;text-align:center}.details-author-large,.stats-row{justify-content:center}}.spec-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;margin-bottom:2.5rem}.spec-item{background:var(--bg-main);padding:1rem 1.25rem;border-radius:12px;border:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:.25rem;transition:all .2s}.spec-item:hover{border-color:var(--brand-light);background:#fff;box-shadow:0 4px 12px #0000000d}.spec-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim)}.spec-value{font-size:.95rem;font-weight:700;color:var(--text-main)}.form-section-header-collapsible{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--bg-main);border-radius:12px;cursor:pointer;transition:all .2s;border:1px solid var(--border-subtle);margin-bottom:1rem}.form-section-header-collapsible:hover{background:#fff;border-color:var(--brand-light);box-shadow:0 4px 12px #0000000d}.collapsible-indicator{margin-left:auto;color:var(--text-dim);transition:transform .3s ease}.collapsible-indicator.open{transform:rotate(180deg);color:var(--brand)}.form-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.form-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}@media(max-width:640px){.form-grid-3,.form-grid-4{grid-template-columns:1fr}}.toast-container{position:fixed;top:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:.75rem;max-width:420px;pointer-events:none}.toast{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#fff;border-radius:var(--radius-lg);box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;border-left:4px solid;pointer-events:auto;animation:toastSlideIn .3s cubic-bezier(.16,1,.3,1);min-width:320px;max-width:420px}@keyframes toastSlideIn{0%{transform:translate(calc(100% + 1.5rem));opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left-color:#10b981}.toast-success .toast-icon{color:#10b981;background:#d1fae5}.toast-error{border-left-color:#ef4444}.toast-error .toast-icon{color:#ef4444;background:#fee2e2}.toast-warning{border-left-color:#f59e0b}.toast-warning .toast-icon{color:#f59e0b;background:#fef3c7}.toast-info{border-left-color:#3b82f6}.toast-info .toast-icon{color:#3b82f6;background:#dbeafe}.toast-icon{flex-shrink:0;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.toast-message{flex:1;font-size:.9375rem;font-weight:600;color:var(--text-main);line-height:1.5}.toast-close{flex-shrink:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.toast-close:hover{background:var(--bg-main);color:var(--text-main)}.toast-close:focus{outline:2px solid var(--brand);outline-offset:2px}@media(max-width:640px){.toast-container{top:auto;bottom:1rem;left:1rem;right:1rem;max-width:none}.toast{min-width:auto;max-width:none}}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-main);padding:2rem}.error-boundary-content{max-width:600px;text-align:center;background:#fff;padding:3rem;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.error-boundary-icon{width:5rem;height:5rem;margin:0 auto 1.5rem;background:#fee2e2;color:#ef4444;border-radius:50%;display:flex;align-items:center;justify-content:center}.error-boundary-title{font-size:1.5rem;font-weight:800;color:var(--text-main);margin-bottom:.75rem}.error-boundary-message{font-size:1rem;color:var(--text-muted);margin-bottom:2rem;line-height:1.6}.error-boundary-details{background:var(--bg-main);padding:1rem;border-radius:var(--radius-md);margin-bottom:2rem;text-align:left;max-height:200px;overflow-y:auto}.error-boundary-details pre{font-size:.8125rem;font-family:Courier New,monospace;color:#ef4444;white-space:pre-wrap;word-break:break-word;margin:0}.loading-spinner{display:inline-block;width:1.5rem;height:1.5rem;border:3px solid rgba(79,70,229,.1);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{position:fixed;inset:0;background:#fffc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9998}.loading-content{text-align:center}.loading-spinner-large{width:3rem;height:3rem;border:4px solid rgba(79,70,229,.1);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}.loading-text{font-size:1rem;font-weight:600;color:var(--text-muted)}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s ease-in-out infinite}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:1rem;border-radius:.25rem}.skeleton-title{height:1.5rem;width:60%;border-radius:.25rem;margin-bottom:.5rem}.skeleton-card{height:300px;border-radius:var(--radius-lg)}.hidden{display:none!important}.image-upload-zone{width:100%;height:160px;border:2px dashed var(--border-subtle);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;background:#fff6;transition:all .4s cubic-bezier(.175,.885,.32,1.275);overflow:hidden;position:relative}.image-upload-zone:hover{border-color:var(--brand);border-style:solid;background:#fff;transform:translateY(-4px);box-shadow:0 15px 30px -5px #4f46e526,var(--shadow-lg)}.image-upload-zone.uploading{border-style:solid;border-color:var(--brand);animation:pulse-border 2s infinite ease-in-out;pointer-events:none}@keyframes pulse-border{0%{box-shadow:0 0 #4f46e533;border-color:var(--brand)}50%{box-shadow:0 0 0 8px #4f46e500;border-color:var(--brand-light)}to{box-shadow:0 0 #4f46e500;border-color:var(--brand)}}.upload-placeholder-wrapper{width:100%;height:100%;cursor:pointer;display:flex;align-items:center;justify-content:center}.upload-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--text-muted);font-weight:600;font-size:.875rem;transition:all .3s ease}.image-upload-zone:hover .upload-placeholder{color:var(--brand)}.upload-icon-container{width:48px;height:48px;border-radius:14px;background:var(--brand-subtle);color:var(--brand);display:flex;align-items:center;justify-content:center;margin-bottom:.25rem;transition:all .3s ease}.image-upload-zone:hover .upload-icon-container{background:var(--brand);color:#fff;transform:rotate(5deg) scale(1.1)}.image-preview-container{width:100%;height:100%;position:relative}.image-preview{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}.image-upload-zone:hover .image-preview{transform:scale(1.05)}.image-preview-overlay{position:absolute;inset:0;background:#0f172a4d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;transition:all .3s ease}.image-preview-container:hover .image-preview-overlay{opacity:1}.image-upload-zone.has-image{border-style:solid;border-color:var(--border-subtle)}.image-upload-zone.has-image:hover{border-color:var(--brand)}.overlay-icon{width:44px;height:44px;background:#fff;color:var(--brand);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);transform:translateY(10px);transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.image-preview-container:hover .overlay-icon{transform:translateY(0)}.input-wrapper .form-input{padding-inline-start:2.75rem}.url-mode-toggle{display:flex;align-items:center;gap:.375rem;padding:.25rem .625rem;background:#fff;border:1px solid var(--border-subtle);border-radius:20px;color:var(--brand);font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm)}.url-mode-toggle:hover{background:var(--brand-subtle);border-color:var(--brand-light);transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000000d}.url-mode-toggle svg{opacity:.8}.status-pill{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;border-radius:9999px;font-size:.625rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;border:1px solid transparent}.status-pill-available{background-color:#f0fdf4;color:#15803d;border-color:#dcfce7}.status-pill-borrowed{background-color:#fef2f2;color:#b91c1c;border-color:#fee2e2}.status-pill-partial{background-color:#fffbeb;color:#b45309;border-color:#fef3c7}.status-pill svg{stroke-width:2.5px}.form-page-container{min-height:100vh;background:var(--bg-main);display:flex;flex-direction:column}.form-page-header{background:#fff;border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:50;padding:1.25rem 2rem}.form-page-header-content{max-width:1400px;margin:0 auto;width:100%;display:flex;align-items:center;gap:1.5rem}.form-back-btn{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--bg-main);color:var(--text-dim);transition:all .2s;border:none;cursor:pointer}.form-back-btn:hover{background:var(--brand-subtle);color:var(--brand);transform:translate(-4px)}.form-page-header-text{flex:1}.form-page-title{font-size:1.5rem;font-weight:800;color:var(--text-main);margin:0;letter-spacing:-.02em}.form-page-subtitle{font-size:.875rem;font-weight:600;color:var(--text-dim);margin:0}.form-page-actions{display:flex;gap:.75rem}.form-page-body{flex:1;padding:2.5rem 2rem;max-width:1400px;margin:0 auto;width:100%}.form-page-split{display:grid;grid-template-columns:1fr 400px;gap:2.5rem;align-items:flex-start}.form-panel-standalone{background:#fff;border:1px solid var(--border-subtle);border-radius:32px;padding:3rem;box-shadow:var(--shadow-sm)}.sticky-preview{display:flex;flex-direction:column;gap:1.5rem}.preview-label{font-size:.7rem;font-weight:800;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.preview-card-wrapper-large{transform:scale(1.05);transform-origin:top center;margin-top:1rem}.form-footer-standalone{margin-top:4rem;padding-top:3rem;border-top:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:1rem}.btn-ghost{background:transparent;color:var(--text-dim);font-weight:700}.btn-ghost:hover{background:var(--bg-main);color:var(--text-main)}@keyframes pulse-soft{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:pulse-soft 2s cubic-bezier(.4,0,.6,1) infinite}@media(max-width:1200px){.form-page-split{grid-template-columns:1fr}.preview-panel-standalone{order:-1;position:static}}@media(max-width:640px){.form-page-header{padding:1rem}.form-page-header-content{gap:1rem}.form-page-actions{display:none}.form-panel-standalone{padding:1.5rem;border-radius:20px}.form-page-body{padding:1rem}}.circulation-container{display:flex;flex-direction:column;gap:2rem;padding-bottom:3rem;max-width:1400px;margin:0 auto}.circulation-hero-card{background:#fff;padding:1.25rem 1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-subtle);margin-bottom:.5rem;position:relative;overflow:hidden}.circulation-hero-card:after{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--brand)}.circulation-hero-card h2{font-size:1.25rem;color:var(--text-main);margin-bottom:.25rem;display:flex;align-items:center;gap:.5rem}.circulation-hero-card p{color:var(--text-muted);font-size:.875rem;max-width:600px}.circulation-stats-bento{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.stat-bento-card{background:#fff;border-radius:var(--radius-lg);padding:1.5rem;display:flex;align-items:center;gap:1.25rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-subtle);transition:all .2s ease;position:relative;overflow:hidden}.stat-bento-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.stat-bento-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px}.stat-bento-card.brand:before{background:var(--brand)}.stat-bento-card.orange:before{background:#f97316}.stat-bento-card.green:before{background:#22c55e}.stat-bento-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-bento-card.brand .stat-bento-icon{background:var(--brand-subtle);color:var(--brand)}.stat-bento-card.orange .stat-bento-icon{background:#ffedd5;color:#f97316}.stat-bento-card.green .stat-bento-icon{background:#dcfce7;color:#22c55e}.stat-bento-info{display:flex;flex-direction:column}.stat-bento-value{font-size:2rem;font-weight:800;color:var(--text-main);line-height:1;margin-bottom:.25rem}.stat-bento-label{font-size:.9rem;font-weight:600;color:var(--text-muted)}.loans-section{display:flex;flex-direction:column;gap:1rem}.loans-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.loans-title{font-size:1.25rem;font-weight:700;color:var(--text-main);display:flex;align-items:center;gap:.75rem}.glass-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border-subtle)}.glass-table thead{background:var(--bg-main)}.glass-table th{padding:1rem 1.5rem;text-align:left;font-size:.8rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-subtle)}.glass-table td{padding:1.25rem 1.5rem;background:#fff;border-bottom:1px solid var(--border-subtle);transition:background .1s}.glass-table tr:last-child td{border-bottom:none}.glass-table tr:hover td{background:var(--brand-subtle)}.borrower-pill{display:flex;align-items:center;gap:.75rem}.borrower-avatar{width:32px;height:32px;border-radius:50%;border:2px solid white;box-shadow:0 0 0 1px var(--border-subtle)}.due-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .75rem;border-radius:20px;font-size:.8rem;font-weight:700;border:1px solid transparent}.due-badge.overdue{background:#fee2e2;color:#ef4444;border-color:#fca5a5}.due-badge.upcoming{background:#ffedd5;color:#f97316;border-color:#fdba74}.due-badge.safe{background:#f1f5f9;color:#64748b;border-color:#cbd5e1}.return-btn-premium{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;background:var(--bg-main);color:var(--text-main);font-size:.85rem;font-weight:600;border:1px solid var(--border-subtle);transition:all .2s}.return-btn-premium:hover{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:0 4px 12px #4f46e54d}.empty-loan-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:#fff;border-radius:var(--radius-lg);border:2px dashed var(--border-subtle)}.empty-loan-icon{width:80px;height:80px;border-radius:50%;background:#f0fdf4;color:#22c55e;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem}.field-tag-section{margin-bottom:1.5rem;padding:1rem;background:var(--bg-main);border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.subsection-title{font-size:.875rem;font-weight:600;color:var(--text-main);display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.add-tag-inline{display:flex;gap:.5rem;margin-bottom:.75rem}.add-tag-inline .form-input{flex:1}.btn-sm{padding:.5rem .75rem;font-size:.75rem}.tag-chips{display:flex;flex-wrap:wrap;gap:.5rem}.tag-chip{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-md);font-size:.8125rem;color:var(--text-main)}.tag-chip-delete{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.125rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .15s ease}.tag-chip-delete:hover{color:#ef4444;background:#fef2f2}.settings-layout{display:grid;grid-template-columns:240px 1fr;gap:0;min-height:calc(100vh - 120px);background:#fff;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg)}.settings-sidebar{background:var(--bg-main);border-right:1px solid var(--border-subtle);padding:1.5rem 0}.settings-sidebar-header{display:flex;align-items:center;gap:.75rem;padding:0 1.5rem 1.5rem;font-size:1.125rem;font-weight:700;color:var(--text-main);border-bottom:1px solid var(--border-subtle);margin-bottom:1rem}.settings-nav{display:flex;flex-direction:column;gap:.25rem;padding:0 .75rem}.settings-nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:transparent;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .15s ease;text-align:left;width:100%}.settings-nav-item:hover{background:#fff;color:var(--text-main)}.settings-nav-item.active{background:#fff;color:var(--brand);font-weight:600;box-shadow:var(--shadow-sm)}.settings-content{padding:2rem;overflow-y:auto}.settings-panel{max-width:700px}.settings-panel-header{margin-bottom:1.5rem}.settings-panel-header h2{display:flex;align-items:center;gap:.75rem;font-size:1.375rem;font-weight:700;color:var(--text-main);margin-bottom:.5rem}.settings-panel-header p{color:var(--text-muted);font-size:.9375rem;line-height:1.5}.settings-page-simple{max-width:800px}.settings-page-simple.full-width{max-width:100%}.settings-header-simple{display:flex;align-items:flex-start;gap:1rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-subtle)}.settings-header-simple>svg{color:var(--brand);flex-shrink:0;margin-top:.25rem}.settings-header-simple h1{font-size:1.5rem;font-weight:700;color:var(--text-main);margin-bottom:.25rem}.settings-header-simple p{font-size:.9375rem;color:var(--text-muted);line-height:1.5}.settings-header-with-action{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-subtle);flex-wrap:wrap}.settings-header-with-action .settings-header-simple{margin-bottom:0;padding-bottom:0;border-bottom:none;flex:1;min-width:200px}.settings-header-with-action .btn{flex-shrink:0}.settings-panel-content{background:#fff;border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-subtle)}.nav-dropdown{margin-bottom:.25rem}.nav-dropdown-toggle{justify-content:flex-start}.nav-chevron{margin-left:auto;transition:transform .2s ease}.nav-chevron.open{transform:rotate(180deg)}.nav-dropdown-items{margin-left:1rem;padding-left:.75rem;border-left:2px solid var(--border-subtle);margin-top:.25rem}.nav-sub-item{display:flex;align-items:center;gap:.625rem;padding:.5rem .75rem;font-size:.8125rem;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all .15s ease;margin-bottom:.125rem}.nav-sub-item:hover{background:var(--brand-subtle);color:var(--text-main)}.nav-sub-item.active{color:var(--brand);font-weight:600;background:var(--brand-subtle)}@media(max-width:768px){.settings-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr}.settings-sidebar{border-right:none;border-bottom:1px solid var(--border-subtle);padding:1rem 0}.settings-sidebar-header{padding:0 1rem 1rem}.settings-nav{flex-direction:row;overflow-x:auto;padding:0 1rem;gap:.5rem}.settings-nav-item{white-space:nowrap;padding:.625rem 1rem}.settings-content{padding:1.5rem}}.preview-book-card{background:linear-gradient(145deg,#fff,#f8fafc);border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 4px 20px #0000000d,0 0 0 1px #00000008;margin-bottom:1rem}.preview-cover-area{position:relative;height:180px;background:linear-gradient(135deg,var(--bg-main) 0%,#e2e8f0 100%);display:flex;align-items:center;justify-content:center;overflow:hidden}.preview-cover-image{width:100%;height:100%;object-fit:cover}.preview-cover-placeholder{display:flex;align-items:center;justify-content:center;width:80px;height:100px;background:#fff;border-radius:var(--radius-md);box-shadow:0 4px 12px #00000014;color:var(--text-muted)}.preview-language-badge{position:absolute;top:.75rem;right:.75rem;display:flex;align-items:center;gap:4px;padding:4px 10px;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:100px;font-size:.6875rem;font-weight:600;color:var(--brand);text-transform:uppercase;letter-spacing:.025em;box-shadow:0 2px 8px #00000014}.preview-book-info{padding:1.25rem}.preview-title{font-size:1.125rem;font-weight:700;color:var(--text-main);line-height:1.3;margin-bottom:.125rem}.preview-title-original{font-size:.75rem;color:var(--text-muted);margin-bottom:.5rem;font-style:italic}.preview-author{font-size:.875rem;font-weight:500;color:var(--brand);margin-bottom:.75rem}.preview-quick-stats{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.preview-stat{display:inline-flex;align-items:center;gap:4px;font-size:.6875rem;color:var(--text-muted);background:var(--bg-main);padding:4px 8px;border-radius:var(--radius-sm)}.preview-isbn{display:inline-block;font-size:.6875rem;font-weight:600;font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-main);padding:4px 10px;border-radius:var(--radius-sm);letter-spacing:.05em}.preview-progress-card{background:#fff;border-radius:var(--radius-lg);padding:1rem;border:1px solid var(--border-subtle);margin-bottom:1rem}.preview-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.625rem}.preview-progress-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.preview-progress-value{font-size:.875rem;font-weight:700;color:var(--brand)}.preview-progress-bar{height:6px;background:var(--bg-main);border-radius:100px;overflow:hidden;margin-bottom:1rem}.preview-progress-fill{height:100%;background:linear-gradient(90deg,var(--brand) 0%,#8b5cf6 100%);border-radius:100px;transition:width .4s cubic-bezier(.4,0,.2,1)}.preview-checklist{display:grid;grid-template-columns:repeat(2,1fr);gap:.375rem}.completion-item{display:flex;align-items:center;gap:.375rem;padding:.25rem 0}.completion-dot{width:6px;height:6px;border-radius:50%;background:#e2e8f0;flex-shrink:0;transition:background .2s ease}.completion-item.done .completion-dot{background:#10b981}.completion-label{font-size:.6875rem;color:#94a3b8;transition:color .2s ease}.completion-item.done .completion-label{color:var(--text-main)}.preview-tags-card{background:#fff;border-radius:var(--radius-lg);padding:1rem;border:1px solid var(--border-subtle)}.preview-tags-label{display:block;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.625rem}.preview-tags-list{display:flex;flex-wrap:wrap;gap:.375rem}.preview-tag{font-size:.6875rem;font-weight:500;color:var(--brand);background:var(--brand-subtle);padding:4px 10px;border-radius:100px}.preview-category{margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-subtle)}.preview-category:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.preview-category-label{display:block;font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.375rem}.preview-meta-small{font-size:.6875rem;color:var(--text-muted);margin-top:-.25rem;margin-bottom:.5rem}.preview-section{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-subtle)}.preview-section-label{display:block;font-size:.5625rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.375rem}.preview-section-content{font-size:.75rem;color:var(--text-main);line-height:1.5}.preview-separator{opacity:.6}.preview-section-items{display:flex;flex-direction:column;gap:.25rem}.preview-mini-row{display:flex;gap:.375rem;font-size:.6875rem;line-height:1.4}.preview-mini-label{color:var(--text-muted);flex-shrink:0}.preview-mini-row>span:last-child{color:var(--text-main)}.preview-description{font-size:.6875rem;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.form-page-split{display:flex;gap:2rem;align-items:flex-start}.form-panel-standalone{flex:1;min-width:0}.preview-panel-standalone{width:340px;flex-shrink:0}.preview-scroll-area{display:flex;flex-direction:column;gap:1rem}@media(max-width:1024px){.form-page-split{flex-direction:column}.preview-panel-standalone{width:100%;order:-1;margin-bottom:1.5rem}}.details-wrapper{max-width:1200px;margin:0 auto;padding:1.5rem;animation:fadeIn .4s ease-out}.details-compact-header{display:flex;align-items:center;margin-bottom:2rem}.back-btn-compact{display:flex;align-items:center;gap:.625rem;padding:.625rem 1.25rem;color:var(--text-secondary);font-weight:600;font-size:.875rem;background:#fff;border:1px solid var(--border-subtle);border-radius:12px;transition:all .2s cubic-bezier(.2,.8,.2,1);box-shadow:0 1px 2px #0000000d}.back-btn-compact:hover{background:var(--bg-subtle);color:var(--text-main);transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a;border-color:var(--brand-light)}.book-details-grid{display:grid;grid-template-columns:340px 1fr;gap:2.5rem;align-items:start}.details-sidebar-sticky{position:sticky;top:2rem;display:flex;flex-direction:column;gap:1.5rem}.details-cover-container{width:100%;aspect-ratio:2/3;border-radius:16px;background:#f8fafc;overflow:hidden;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;position:relative;transition:transform .3s ease;border:1px solid rgba(0,0,0,.04)}.details-cover-container:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.details-cover-container img{width:100%;height:100%;object-fit:cover}.cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#cbd5e1;background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.details-actions-stack{display:flex;flex-direction:column;gap:.75rem}.details-main-content{display:flex;flex-direction:column;gap:2rem;min-width:0}.book-header-section{padding-bottom:2rem;border-bottom:1px solid var(--border-subtle)}.book-title-huge{font-size:2.25rem;font-weight:800;color:var(--text-main);line-height:1.25;margin-bottom:.75rem;letter-spacing:-.02em}.book-meta-row{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.25rem}.author-link{display:inline-flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:600;color:var(--brand);padding:.25rem .5rem;margin:-.25rem -.5rem;border-radius:6px;transition:background .2s ease}.author-link:hover{background:var(--brand-light)}.meta-divider{width:4px;height:4px;border-radius:50%;background:var(--text-muted);opacity:.4}.alt-title{color:var(--text-secondary);font-size:1rem;line-height:1.5}.metadata-grid-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.metadata-card{background:#fff;border:1px solid var(--border-subtle);border-radius:16px;padding:1.5rem;height:100%;transition:all .2s ease;box-shadow:0 1px 3px #0000000d}.metadata-card:hover{box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;border-color:var(--brand-subtle)}.metadata-card-title{display:flex;align-items:center;gap:.625rem;font-size:.95rem;font-weight:700;color:var(--text-main);margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-subtle)}.metadata-card-title svg{color:var(--brand);opacity:.9}.status-banner{border-radius:16px;padding:1.25rem 1.5rem;display:flex;align-items:center;gap:1.25rem;margin-bottom:2rem;border:1px solid transparent;box-shadow:0 4px 6px -1px #0000000d}.status-banner-icon-bg{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#fff9}.status-banner.borrowed{background:linear-gradient(135deg,#fff1f2,#ffe4e6);border-color:#fecdd3;color:#9f1239}.status-banner.available{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-color:#a7f3d0;color:#065f46}.status-banner.partial{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-color:#fde68a;color:#92400e}.volume-inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.volume-item-card{background:#fff;border:1px solid var(--border-subtle);border-radius:12px;padding:1rem;transition:all .2s cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden}.volume-item-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a;border-color:var(--brand-light)}.volume-item-card.is-available{border-left:3px solid #10b981}.volume-item-card.is-loaned{border-left:3px solid #f59e0b}.volume-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.volume-number-badge{font-size:.75rem;font-weight:700;color:var(--text-secondary);background:var(--bg-subtle);padding:.25rem .5rem;border-radius:6px;letter-spacing:.05em}.volume-status-indicator{display:inline-flex;align-items:center;gap:.25rem;font-size:.7rem;font-weight:700;text-transform:uppercase;padding:.125rem .5rem;border-radius:100px}.volume-status-indicator.available{background:#ecfdf5;color:#059669}.volume-status-indicator.loaned{background:#fffbeb;color:#d97706}.compact-spec-row{display:flex;border-bottom:1px solid var(--border-subtle);padding:.75rem 0}.compact-spec-row:last-child{border-bottom:none;padding-bottom:0}.compact-spec-row:first-child{padding-top:0}.compact-spec-label{width:40%;font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.compact-spec-value{width:60%;font-size:.9rem;font-weight:600;color:var(--text-main)}.sample-image-preview{width:100%;border-radius:16px;overflow:hidden;border:1px solid var(--border-subtle);margin-top:1rem;box-shadow:0 4px 6px -1px #0000000d}@media(max-width:900px){.book-details-grid{grid-template-columns:1fr;gap:1.5rem}.details-sidebar-sticky{position:relative;top:0;flex-direction:row;align-items:flex-start}.details-cover-container{width:140px;flex-shrink:0}}@media(max-width:640px){.details-sidebar-sticky{flex-direction:column}.details-cover-container{width:100%;max-width:220px;margin:0 auto}.book-title-huge{font-size:1.75rem}}.action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:none;background:var(--bg-subtle);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.action-btn:hover{transform:scale(1.05)}.action-btn-view:hover{background:var(--brand-light);color:var(--brand)}.action-btn-delete:hover{background:#ef44441a;color:#ef4444}.book-card-footer{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-top:1px solid var(--border-subtle);background:var(--bg-subtle)}.book-card-delete{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.book-card-delete:hover{background:#ef44441a;color:#ef4444;transform:scale(1.05)}.sidebar-add-btn{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;margin-bottom:1rem;background:var(--brand);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.sidebar-add-btn:hover{background:var(--brand-dark);transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.search-overlay{width:100%;min-height:400px}.search-overlay-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.search-overlay-header h3{font-size:1.25rem;font-weight:700;color:var(--text-main)}.search-overlay-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:none;background:var(--bg-subtle);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.search-overlay-close:hover{background:#ef44441a;color:#ef4444}.search-overlay-loading,.search-overlay-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--text-secondary)}.search-overlay-empty p{margin-top:1rem;font-size:1rem}.search-results-count{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:1rem}.search-results-list{display:flex;flex-direction:column;gap:.75rem}.search-result-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border:1px solid var(--border-subtle);border-radius:12px;cursor:pointer;transition:all .2s ease}.search-result-item:hover{border-color:var(--brand);box-shadow:0 4px 12px #6366f11a;transform:translateY(-2px)}.search-result-cover{width:48px;height:64px;border-radius:6px;overflow:hidden;background:linear-gradient(135deg,var(--brand-light) 0%,var(--brand) 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0}.search-result-cover img{width:100%;height:100%;object-fit:cover}.search-result-cover .cover-letter{font-size:1.25rem;font-weight:700;color:#fff}.search-result-info{flex:1;min-width:0}.search-result-title{font-size:1rem;font-weight:700;color:var(--text-main);margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-result-author{font-size:.875rem;font-weight:600;color:var(--brand);margin-bottom:.5rem}.search-result-meta{display:flex;flex-wrap:wrap;gap:.5rem}.search-result-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-radius:4px;background:var(--bg-subtle);color:var(--text-secondary)}.search-result-badge.available{background:#22c55e1a;color:#22c55e}.search-result-badge.checked-out{background:#ef44441a;color:#ef4444}.search-result-view{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:none;background:transparent;color:var(--text-secondary);transition:all .2s ease}.search-result-item:hover .search-result-view{background:var(--brand-light);color:var(--brand)}.search-result-actions{display:flex;gap:.25rem;flex-shrink:0}.action-btn-checkout:hover{background:#3b82f61a;color:#3b82f6}.action-btn-return:hover{background:#22c55e1a;color:#22c55e}.autocomplete-wrapper{position:relative;width:100%}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;z-index:100;margin-top:4px;background:#fff;border:1px solid var(--border-subtle);border-radius:10px;box-shadow:0 8px 24px #0000001f;max-height:280px;overflow-y:auto}.autocomplete-option{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;cursor:pointer;transition:all .15s ease;color:var(--text-main)}.autocomplete-option:hover{background:var(--brand-light)}.autocomplete-option.selected{background:var(--brand-light);color:var(--brand);font-weight:600}.autocomplete-divider{height:1px;background:var(--border-subtle);margin:.25rem 0}.autocomplete-save-option{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;cursor:pointer;color:#22c55e;font-weight:600;transition:all .15s ease}.autocomplete-save-option:hover{background:#22c55e1a}.autocomplete-save-prompt{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem 1rem;margin-top:4px;background:#22c55e0d;border:1px solid rgba(34,197,94,.2);border-radius:8px;font-size:.875rem;color:var(--text-main)}.autocomplete-save-actions{display:flex;gap:.5rem}.autocomplete-save-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;background:#22c55e;color:#fff;border:none;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s ease}.autocomplete-save-btn:hover{background:#16a34a}.autocomplete-dismiss-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:transparent;color:var(--text-secondary);border:none;border-radius:4px;cursor:pointer;transition:all .15s ease}.autocomplete-dismiss-btn:hover{background:#ef44441a;color:#ef4444}.input-wrapper{position:relative;display:flex;align-items:center}.input-wrapper .form-input{width:100%}.input-icon{position:absolute;left:12px;display:flex;align-items:center;color:var(--text-secondary);pointer-events:none;z-index:1}.input-wrapper.has-icon .form-input{padding-left:36px}.form-input{padding:.75rem 1rem}.form-input::placeholder{padding:0;text-indent:0}td[dir=auto],th[dir=auto]{text-align:start;unicode-bidi:plaintext}.book-table td:first-child,.book-table td:nth-child(2){text-align:start;unicode-bidi:plaintext}.book-card-title,.book-card-author{text-align:start;unicode-bidi:plaintext}[dir=rtl],:lang(ar),:lang(ur),:lang(fa),:lang(he){text-align:right}[dir=auto]{unicode-bidi:plaintext;text-align:start}.search-result-title,.search-result-author{text-align:start;unicode-bidi:plaintext}.font-arabic,[lang=ar],[lang=ur],[lang=fa]{font-family:Amiri,Traditional Arabic,Noto Naskh Arabic,serif;line-height:1.8}.book-table-wrapper{width:100%;overflow-x:auto}.book-table{width:100%;table-layout:fixed;border-collapse:collapse}.book-table thead th{white-space:nowrap;padding:.75rem .5rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle)}.book-table tbody td{padding:.75rem .5rem;vertical-align:middle;border-bottom:1px solid var(--border-subtle)}.book-table th:nth-child(1),.book-table td:nth-child(1){width:25%}.book-table th:nth-child(2),.book-table td:nth-child(2){width:15%}.book-table th:nth-child(3),.book-table td:nth-child(3){width:10%}.book-table th:nth-child(4),.book-table td:nth-child(4){width:8%}.book-table th:nth-child(5),.book-table td:nth-child(5){width:12%}.book-table th:nth-child(6),.book-table td:nth-child(6){width:12%}.book-table th:nth-child(7),.book-table td:nth-child(7){width:18%}.book-table td:nth-child(1),.book-table td:nth-child(2),.book-table td:nth-child(5){overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:0}.book-table td[title]{cursor:help}.table-row-clickable{cursor:pointer;transition:background-color .15s ease}.table-row-clickable:hover{background-color:var(--bg-subtle)}.table-actions{display:flex;gap:.25rem;justify-content:flex-end}.modal-overlay{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-container{background:#fff;border-radius:1.25rem;box-shadow:0 25px 50px -12px #00000040;width:100%;max-width:28rem;max-height:90vh;overflow:hidden;animation:slideUp .3s ease-out}.modal-container.max-w-md{max-width:28rem}.modal-header{display:flex;align-items:center;gap:1rem;padding:1.5rem;border-bottom:1px solid var(--border-subtle);background:linear-gradient(135deg,var(--bg-subtle) 0%,white 100%)}.modal-header-icon{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:.875rem;flex-shrink:0}.modal-header-icon.bg-brand\/10{background:#6366f11a}.modal-header-icon.text-brand{color:var(--brand)}.modal-header-text{flex:1;min-width:0}.modal-title{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin:0}.modal-subtitle{font-size:.875rem;color:var(--text-secondary);margin:.25rem 0 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-footer{display:flex;gap:.75rem;justify-content:center;align-items:center;padding:1.5rem;margin-top:0;background:#fff;border-radius:0 0 1.25rem 1.25rem}.modal-footer .btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;font-weight:600;min-width:120px;height:44px}.modal-container .input-wrapper{position:relative;display:flex;align-items:center}.modal-container .input-icon{position:absolute;left:1rem;color:var(--text-secondary);pointer-events:none;z-index:1}.modal-container .form-input.has-icon{padding-left:2.75rem}.modal-container .p-6{padding:1.5rem}.modal-container .space-y-4>*+*{margin-top:1rem}.modal-container .pt-4{padding-top:1rem}.modal-container .px-0{padding-left:0;padding-right:0}.modal-container .pb-0{padding-bottom:0}.modal-container .form-group{margin-top:0}.modal-container .form-label{margin-bottom:.5rem;display:block}.modal-container .form-input{width:100%;transition:border-color .2s,box-shadow .2s}.modal-container .form-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #6366f11a}.quick-date-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.quick-date-btn{padding:.625rem .75rem;border-radius:.5rem;border:1px solid var(--border-color);background:#fff;color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s ease;text-align:center;white-space:nowrap}.quick-date-btn:hover{border-color:var(--brand);color:var(--brand)}.quick-date-btn.active{background:var(--brand);border-color:var(--brand);color:#fff}.date-preview{margin-top:.5rem;font-size:.8125rem;color:var(--text-secondary);background:var(--bg-subtle);padding:.5rem .75rem;border-radius:.5rem}.mt-2{margin-top:.5rem}input[type=date]{color-scheme:light;cursor:pointer}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;padding:4px;border-radius:4px;transition:background-color .15s}input[type=date]::-webkit-calendar-picker-indicator:hover{background-color:#6366f11a}input[type=date]::-webkit-inner-spin-button,input[type=date]::-webkit-clear-button{display:none}input[type=date]:not(:valid):before{content:attr(placeholder);color:var(--text-secondary)}.modal-container input[type=date]{appearance:none;-webkit-appearance:none;background-color:#fff;border:1px solid var(--border-color);border-radius:.75rem;color:var(--text-primary)}.modal-container input[type=date]:focus{border-color:var(--brand);outline:none;box-shadow:0 0 0 3px #6366f11a}.recently-deleted-page{max-width:900px}.recently-deleted-page .page-header{position:relative;padding:0;background:transparent;border:none;-webkit-backdrop-filter:none;backdrop-filter:none;margin-bottom:2rem}.page-header-content{display:flex;align-items:center;gap:1rem}.page-header-icon{color:var(--text-dim)}.page-subtitle{color:var(--text-muted);font-size:.875rem;margin-top:.25rem}.empty-trash{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;background:#fff;border-radius:var(--radius-xl);border:2px dashed var(--border-subtle)}.empty-trash-icon{color:var(--text-dim);opacity:.5;margin-bottom:1.5rem}.empty-trash h2{color:var(--text-muted);font-size:1.25rem;font-weight:700;margin-bottom:.5rem}.empty-trash p{color:var(--text-dim);font-size:.9rem}.deleted-books-list{display:flex;flex-direction:column;gap:1rem}.deleted-book-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);position:relative;transition:all .2s ease}.deleted-book-card:hover{box-shadow:var(--shadow-md);border-color:var(--brand-light)}.deleted-book-cover{width:60px;height:80px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0;background:var(--bg-main)}.deleted-book-cover img{width:100%;height:100%;object-fit:cover}.deleted-book-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-dim)}.deleted-book-info{flex:1;min-width:0}.deleted-book-title{font-size:1rem;font-weight:700;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.deleted-book-author{font-size:.875rem;color:var(--text-muted);margin-top:.125rem}.deleted-book-meta{display:flex;align-items:center;gap:.375rem;margin-top:.5rem;font-size:.75rem;color:var(--text-dim)}.deleted-book-actions{display:flex;align-items:center;gap:.5rem}.btn-restore{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--brand-subtle);color:var(--brand);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-restore:hover{background:var(--brand);color:#fff}.btn-permanent-delete{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;color:var(--text-dim);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.btn-permanent-delete:hover{background:#fef2f2;color:#ef4444;border-color:#fecaca}.confirm-delete-overlay{position:absolute;inset:0;background:#fffffff2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;z-index:10}.confirm-delete-content{display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center}.confirm-delete-content .warning-icon{color:#f59e0b}.confirm-delete-content p{font-weight:600;color:var(--text-main)}.confirm-delete-actions{display:flex;gap:.5rem}.btn-danger{background:#ef4444;color:#fff;border:none}.btn-danger:hover{background:#dc2626}.recently-deleted-page .library-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.recently-deleted-page .library-header-left,.recently-deleted-page .library-title-group{display:flex;align-items:center;gap:1rem}.recently-deleted-page .library-icon{color:var(--text-dim)}.recently-deleted-page .page-title{font-size:1.75rem;font-weight:800;color:var(--text-main);margin:0}.deleted-date{font-size:.8rem;color:var(--text-muted)}.btn-restore-sm{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:var(--brand-subtle);color:var(--brand);border:none;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-restore-sm:hover{background:var(--brand);color:#fff}.btn-delete-sm{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;color:var(--text-dim);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.btn-delete-sm:hover{background:#fef2f2;color:#ef4444;border-color:#fecaca}.deleted-card{position:relative}.deleted-card .deleted-overlay{position:absolute;bottom:0;left:0;right:0;padding:.5rem;background:linear-gradient(transparent,#000000b3);display:flex;align-items:center;gap:.375rem;color:#fff;font-size:.7rem}.book-card-actions{display:flex;gap:.5rem;padding:.75rem;border-top:1px solid var(--border-subtle)}.btn-restore-card{flex:1;display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem;background:var(--brand-subtle);color:var(--brand);border:none;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-restore-card:hover{background:var(--brand);color:#fff}.btn-delete-card{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;color:var(--text-dim);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.btn-delete-card:hover{background:#fef2f2;color:#ef4444;border-color:#fecaca}.confirm-modal{max-width:400px;text-align:center}.confirm-modal-content{padding:2rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.confirm-modal-content .warning-icon-lg{color:#f59e0b}.confirm-modal-content h2{font-size:1.25rem;color:var(--text-main);margin:0}.confirm-modal-content p{color:var(--text-muted);font-size:.9rem;margin:0}.confirm-modal-actions{display:flex;gap:.75rem;margin-top:.5rem}.restore-btn-card{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:var(--brand-subtle);color:var(--brand);border:none;border-radius:8px;font-size:.75rem;font-weight:700;cursor:pointer;transition:all .2s ease}.restore-btn-card:hover{background:var(--brand);color:#fff}.theme-section{margin-bottom:2rem}.theme-description{color:var(--text-muted);font-size:.875rem;margin-bottom:1.5rem}.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem}.theme-swatch{display:flex;flex-direction:column;align-items:center;gap:.625rem;padding:.75rem;background:#fff;border:2px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease}.theme-swatch:hover{border-color:var(--brand-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}.theme-swatch.active{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-subtle)}.theme-swatch-color{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.theme-swatch-color .check-icon{color:#fff}.theme-swatch-name{font-size:.8rem;font-weight:600;color:var(--text-main)}.theme-preview{padding:1.5rem;background:var(--bg-main);border-radius:var(--radius-lg);margin-top:1.5rem}.theme-preview h4{font-size:.875rem;font-weight:700;color:var(--text-muted);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em}.preview-buttons{display:flex;gap:1rem;flex-wrap:wrap}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:60px;background:#fffffff2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);z-index:100;padding:0 1rem;align-items:center;justify-content:space-between}.hamburger-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:10px;color:var(--text-main);cursor:pointer;transition:background .2s ease}.hamburger-btn:hover{background:var(--bg-main)}.mobile-logo{display:flex;align-items:center;gap:.5rem;font-weight:800;font-size:1.1rem;color:var(--text-main)}.mobile-logo svg{color:var(--brand)}.mobile-header-spacer{width:44px}.sidebar-backdrop{display:none;position:fixed;inset:0;background:#00000080;z-index:150;animation:fadeIn .2s ease}.sidebar-close-btn{display:none;position:absolute;top:1rem;right:1rem;width:40px;height:40px;align-items:center;justify-content:center;background:var(--bg-main);border:none;border-radius:10px;color:var(--text-muted);cursor:pointer;transition:all .2s ease;z-index:10}[dir=rtl] .sidebar-close-btn{right:auto;left:1rem}.sidebar-close-btn:hover{background:var(--brand-subtle);color:var(--brand)}@media(max-width:768px){.mobile-header{display:flex}.main-content{padding-top:60px}.p-content{padding:1.25rem 1.25rem 4rem}.sidebar{position:fixed;top:0;left:0;height:100vh;width:280px;transform:translate(-100%);z-index:200;box-shadow:var(--shadow-xl)}[dir=rtl] .sidebar{left:auto;right:0;transform:translate(100%)}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block}.sidebar-close-btn{display:flex}.sidebar-header{padding-right:3.5rem}[dir=rtl] .sidebar-header{padding-right:1.5rem;padding-left:3.5rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-card{padding:1rem}.stat-value{font-size:1.5rem}.books-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.view-controls-bar{flex-wrap:wrap;gap:.75rem}.controls-left{flex-wrap:wrap}.glass-table{min-width:600px}.overflow-x-auto{overflow-x:auto;-webkit-overflow-scrolling:touch}.form-page-header-content{flex-wrap:wrap;gap:1rem}.form-page-actions{width:100%;justify-content:flex-end}.form-page-split{flex-direction:column}.form-preview-panel{position:static;width:100%}.circulation-stats-bento{grid-template-columns:1fr}.filter-modal{width:95%;max-width:400px;margin:1rem}.book-details-layout{flex-direction:column}.book-details-sidebar{width:100%;position:static}}@media(max-width:480px){.mobile-header{padding:0 .75rem}.p-content{padding:1rem 1rem 3rem}.stats-grid{grid-template-columns:1fr}.books-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.view-toggle-buttons{display:none}.btn{padding:.625rem 1rem;font-size:.8rem}}.isbn-quick-lookup{background:linear-gradient(135deg,#4f46e514,#9333ea0f);border:1.5px solid rgba(79,70,229,.2);border-radius:var(--radius-xl);padding:1.25rem 1.5rem;margin-bottom:1.5rem}.isbn-quick-header{display:flex;align-items:center;gap:.875rem;margin-bottom:1rem}.isbn-quick-icon{width:42px;height:42px;background:linear-gradient(135deg,var(--brand) 0%,#7c3aed 100%);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.isbn-quick-title{font-size:1rem;font-weight:700;color:var(--text-main);margin-bottom:.125rem}.isbn-quick-subtitle{font-size:.8125rem;color:var(--text-muted)}.isbn-quick-input-row{display:flex;gap:.75rem}.isbn-quick-input{flex:1;font-size:1rem!important;padding:.875rem 1rem!important}.isbn-quick-btn{padding:.875rem 1.5rem!important;font-size:.9375rem!important;white-space:nowrap}@media(max-width:640px){.isbn-quick-input-row{flex-direction:column}.isbn-quick-btn{width:100%;justify-content:center}}.form-notification{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:var(--radius-lg);margin-bottom:1.25rem;font-size:.875rem;font-weight:500;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.form-notification.success{background:#16a34a1a;border:1px solid rgba(22,163,74,.2);color:#16a34a}.form-notification.error{background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#dc2626}.form-notification span{flex:1}.form-notification-close{display:flex;align-items:center;justify-content:center;padding:.25rem;background:transparent;border:none;border-radius:4px;cursor:pointer;opacity:.6;transition:opacity .2s}.form-notification-close:hover{opacity:1}.volume-tracking-toggle{margin-top:.5rem}.toggle-switch{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:var(--bg-main);border:1px dashed var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease}.toggle-switch:hover{border-color:var(--brand-light);background:#4f46e508}.toggle-switch.active{border-style:solid;border-color:var(--brand);background:#4f46e50d}.toggle-switch svg{flex-shrink:0;color:var(--text-dim);transition:color .2s}.toggle-switch.active svg{color:var(--brand)}.toggle-label{display:block;font-weight:600;color:var(--text-main);font-size:.9375rem}.toggle-desc{display:block;font-size:.8125rem;color:var(--text-muted);margin-top:.125rem}.isbn-input-wrapper{display:flex;gap:.5rem}.isbn-input-wrapper .form-input{flex:1}.isbn-fetch-btn{display:flex;align-items:center;gap:.375rem;padding:0 1rem;background:var(--brand);color:#fff;border:none;border-radius:var(--radius-lg);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.isbn-fetch-btn:hover:not(:disabled){background:var(--brand-dark);transform:translateY(-1px)}.isbn-fetch-btn:disabled{opacity:.5;cursor:not-allowed}.isbn-fetch-btn .animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.data-section,.data-management-section{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border-subtle)}.data-management-section:first-child{margin-top:0;padding-top:0;border-top:none}.data-actions{display:flex;gap:1rem;flex-wrap:wrap}.data-actions .btn{min-width:180px}.import-modal{background:#fff;border-radius:var(--radius-xl);width:90%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);animation:slideUp .3s ease}.import-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border-subtle)}.import-modal-header h2{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;color:var(--text-main)}.import-modal-header h2 svg{color:var(--brand)}.import-modal-body{padding:1.5rem;overflow-y:auto;flex:1}.import-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-subtle);background:var(--bg-main);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.import-dropzone{margin-bottom:1rem}.sample-download-section{display:flex;justify-content:center;margin-bottom:1.5rem}.sample-download-btn{font-size:.8125rem;padding:.5rem 1rem;gap:.5rem}.dropzone-btn{width:100%;padding:2.5rem;display:flex;flex-direction:column;align-items:center;gap:1rem;background:var(--bg-main);border:2px dashed var(--border-muted);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease}.dropzone-btn:hover{border-color:var(--brand);background:var(--brand-subtle)}.dropzone-btn svg{color:var(--brand)}.dropzone-text{font-size:1rem;font-weight:600;color:var(--text-main)}.dropzone-hint{font-size:.75rem;color:var(--text-muted);text-align:center;max-width:300px}.import-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md);color:#dc2626;font-size:.875rem;margin-bottom:1rem}.import-preview h4{font-size:.875rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.preview-table-wrapper{overflow-x:auto;border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.preview-table{width:100%;border-collapse:collapse;font-size:.875rem}.preview-table th,.preview-table td{padding:.625rem .75rem;text-align:left;border-bottom:1px solid var(--border-subtle)}.preview-table th{background:var(--bg-main);font-weight:600;color:var(--text-muted);font-size:.75rem;text-transform:uppercase}.preview-table tbody tr:last-child td{border-bottom:none}.preview-more{font-size:.8rem;color:var(--text-muted);font-style:italic;margin-top:.75rem;text-align:center}.import-success{display:flex;flex-direction:column;align-items:center;padding:2rem;text-align:center}.import-success .success-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:#dcfce7;color:#16a34a;border-radius:50%;margin-bottom:1.5rem}.import-success h3{font-size:1.5rem;font-weight:700;color:var(--text-main);margin-bottom:.5rem}.import-success p{color:var(--text-muted);margin-bottom:1.5rem}.load-more-wrapper{display:flex;justify-content:center;padding:2rem 0;margin-top:1rem}.load-more-btn{min-width:200px}.patrons-page{width:100%}.patrons-hero{display:flex;align-items:center;gap:1.5rem;padding:2rem;background:linear-gradient(135deg,var(--brand-subtle) 0%,white 100%);border-radius:var(--radius-xl);margin-bottom:2rem;border:1px solid var(--border-subtle)}.patrons-hero .hero-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--brand);color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.patrons-hero h1{font-size:1.75rem;font-weight:800;color:var(--text-main);margin-bottom:.25rem}.patrons-hero p{color:var(--text-muted);font-size:.95rem}.patrons-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.search-wrapper{position:relative;flex:1;max-width:400px}.search-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input{width:100%;padding:.75rem 2.5rem .75rem 2.75rem;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);font-size:.875rem;background:#fff;transition:all .2s ease}.search-input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-subtle)}.search-clear{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:var(--bg-main);border:none;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted)}.search-clear:hover{background:var(--border-subtle);color:var(--text-main)}.patron-add-btn{margin-bottom:1.5rem}.patrons-table .patron-name-cell{display:flex;align-items:center;gap:.75rem}.patron-avatar-sm{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--brand);color:#fff;font-weight:700;font-size:.875rem;border-radius:50%;flex-shrink:0}.patrons-table .patron-name{font-weight:600;color:var(--text-main)}.patrons-table .meta-text{display:flex;align-items:center;gap:.375rem;color:var(--text-muted);font-size:.875rem}.patrons-table .notes-text{font-size:.875rem;color:var(--text-muted);font-style:italic;max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.patrons-table tr.clickable{cursor:pointer}.patrons-table tr.clickable:hover{background:var(--brand-subtle)}.patrons-table tr.editing{background:var(--bg-main)}.inline-edit-form{display:flex;align-items:center;gap:.75rem;width:100%}.inline-edit-form .form-input{padding:.5rem .75rem;font-size:.875rem}.inline-edit-actions{display:flex;gap:.5rem;flex-shrink:0}.results-count{margin-top:1rem;text-align:center;font-size:.8rem;color:var(--text-muted)}@media(max-width:768px){.patrons-toolbar{flex-direction:column;align-items:stretch}.search-wrapper{max-width:none}}.patron-form{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}.patron-form h3{font-size:1.1rem;font-weight:700;color:var(--text-main);margin-bottom:1rem}.patron-form .form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.patrons-list{display:flex;flex-direction:column;gap:.75rem}.patron-card{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all .2s ease}.patron-card:hover{border-color:var(--brand-light);box-shadow:var(--shadow-sm)}.patron-info{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.patron-avatar{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--brand);color:#fff;font-weight:700;font-size:1.1rem;border-radius:50%;flex-shrink:0}.patron-details{min-width:0;flex:1}.patron-name{font-size:1rem;font-weight:700;color:var(--text-main);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.patron-meta{display:flex;flex-wrap:wrap;gap:1rem;font-size:.8rem;color:var(--text-muted)}.patron-meta span{display:flex;align-items:center;gap:.375rem}.patron-notes{font-style:italic}.patron-name-row{display:flex;align-items:center;gap:.75rem}.active-loan-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;background:#fff7ed;color:#ea580c;font-size:.8rem;font-weight:600;border-radius:var(--radius-full);border:1px solid #fed7aa;white-space:nowrap}.active-loan-badge svg{flex-shrink:0;width:14px;height:14px}.patron-actions{display:flex;gap:.5rem}.patron-edit-form{width:100%}.patron-edit-form .form-grid-2{margin-bottom:1rem}.edit-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.75rem}.btn-sm{padding:.5rem .875rem;font-size:.8rem}@media(max-width:600px){.patron-meta{flex-direction:column;gap:.375rem}.patron-info{flex-direction:column;align-items:flex-start}.patron-card{flex-direction:column;align-items:flex-start;gap:1rem}.patron-actions{width:100%;justify-content:flex-end}}.patron-card.expanded{flex-direction:column;align-items:stretch}.patron-main{display:flex;align-items:center;justify-content:space-between;flex:1;cursor:pointer;min-width:0}.patron-summary{display:flex;align-items:center;gap:1rem;color:var(--text-muted)}.loan-count{display:flex;align-items:center;gap:.375rem;font-size:.8rem;background:var(--bg-main);padding:.375rem .75rem;border-radius:var(--radius-md)}.patron-history{width:100%;padding-top:1rem;margin-top:1rem;border-top:1px solid var(--border-subtle)}.patron-history h5{font-size:.85rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.history-loading,.history-empty{font-size:.875rem;color:var(--text-muted);font-style:italic}.history-list{display:flex;flex-direction:column;gap:.5rem}.history-section-title{display:flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-top:.75rem;margin-bottom:.25rem}.history-section-title:first-child{margin-top:0}.history-item{display:flex;align-items:flex-start;gap:.75rem;padding:.625rem .75rem;background:var(--bg-main);border-radius:var(--radius-md);font-size:.875rem}.history-item svg{flex-shrink:0;margin-top:.125rem}.history-item.active{background:var(--brand-subtle);border:1px solid var(--brand-light)}.history-item.active svg{color:var(--brand)}.history-item.returned{background:var(--bg-main)}.history-item.returned svg{color:var(--text-muted)}.history-details{display:flex;flex-direction:column;gap:.125rem;min-width:0}.history-title{font-weight:600;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-date{font-size:.75rem;color:var(--text-muted)}.history-more{font-size:.8rem;color:var(--text-muted);font-style:italic;margin-top:.5rem}.patron-card.clickable{cursor:pointer}.patron-card.clickable:hover{border-color:var(--brand);box-shadow:var(--shadow-md)}.patron-row{display:flex;align-items:center;justify-content:space-between;width:100%;gap:1rem}.patron-row-actions{display:flex;align-items:center;gap:.5rem}.chevron-icon{color:var(--text-muted);opacity:.5;transition:all .2s ease}.patron-card.clickable:hover .chevron-icon{opacity:1;color:var(--brand);transform:translate(2px)}.patron-detail-page{width:100%}.back-link{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 0;color:var(--text-muted);font-size:.875rem;font-weight:500;border:none;background:none;cursor:pointer;transition:color .2s ease;margin-bottom:1rem}.back-link:hover{color:var(--brand)}.patron-detail-hero{display:flex;align-items:center;gap:1.5rem;padding:2rem;background:linear-gradient(135deg,var(--brand-subtle) 0%,white 100%);border-radius:var(--radius-xl);border:1px solid var(--border-subtle);margin-bottom:2rem}.patron-detail-avatar{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:var(--brand);color:#fff;font-weight:700;font-size:2rem;border-radius:50%;flex-shrink:0;box-shadow:var(--shadow-md)}.patron-detail-info h1{font-size:1.75rem;font-weight:800;color:var(--text-main);margin-bottom:.5rem}.patron-detail-meta{display:flex;flex-wrap:wrap;gap:1.25rem;color:var(--text-muted);font-size:.95rem}.patron-detail-meta span{display:flex;align-items:center;gap:.5rem}.patron-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.patron-stat-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.patron-history-section{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:1.5rem}.patron-history-section h2{font-size:1.25rem;font-weight:700;color:var(--text-main);margin-bottom:1.5rem}.patron-history-section .empty-state.compact{padding:2rem}.history-section{margin-bottom:2rem}.history-section:last-child{margin-bottom:0}.history-section h3{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.history-cards{display:flex;flex-direction:column;gap:.75rem}.loan-card{display:flex;align-items:flex-start;gap:1rem;padding:1rem;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease}.loan-card:hover{transform:translate(4px)}.loan-card.active{background:var(--brand-subtle);border:1px solid var(--brand-light)}.loan-card.active svg{color:var(--brand)}.loan-card.returned{background:var(--bg-main);border:1px solid var(--border-subtle)}.loan-card.returned svg{color:var(--text-muted)}.loan-card svg{flex-shrink:0;margin-top:.125rem}.loan-details{display:flex;flex-direction:column;gap:.375rem;min-width:0}.loan-title{font-size:1rem;font-weight:600;color:var(--text-main)}.loan-dates{display:flex;flex-wrap:wrap;gap:1rem;font-size:.8rem;color:var(--text-muted)}.loan-dates span{display:flex;align-items:center;gap:.375rem}.due-date{color:var(--brand);font-weight:500}@media(max-width:600px){.patron-detail-hero{flex-direction:column;text-align:center}.patron-detail-meta{justify-content:center}.patron-stats-grid{grid-template-columns:1fr}}.controls-right{display:flex;align-items:center;gap:.75rem}.patron-grid-card{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-xl);overflow:hidden;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column}.patron-grid-card:hover{border-color:var(--brand);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.patron-card-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:linear-gradient(135deg,var(--brand-subtle) 0%,white 100%)}.patron-avatar-lg{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--brand);color:#fff;font-weight:700;font-size:1.5rem;border-radius:50%;box-shadow:var(--shadow-md)}.patron-card-content{padding:1rem;flex:1}.patron-card-name{font-size:1.1rem;font-weight:700;color:var(--text-main);margin-bottom:.5rem}.patron-card-meta{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;color:var(--text-muted)}.patron-card-meta span{display:flex;align-items:center;gap:.375rem}.patron-card-notes{margin-top:.75rem;font-size:.8rem;color:var(--text-muted);font-style:italic;line-height:1.4}.patron-card-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:.75rem 1rem;border-top:1px solid var(--border-subtle);background:var(--bg-main)}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0f172a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.modal-container{background:#fff;width:90%;max-width:500px;border-radius:20px;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;overflow:hidden;animation:scaleIn .2s cubic-bezier(.16,1,.3,1)}.modal-header{display:flex;align-items:center;gap:1rem;padding:1.5rem;border-bottom:1px solid var(--border-subtle)}.modal-header-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.modal-header-text{flex:1}.modal-title{font-size:1.125rem;font-weight:800;color:var(--text-main);line-height:1.2;margin-bottom:2px}.modal-subtitle{font-size:.8rem;color:var(--text-muted);font-weight:600}.modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.modal-footer{padding:1.25rem 1.5rem;background:#fff;border-top:none;display:flex;justify-content:center;gap:.75rem}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.book-info-chips{display:flex;flex-wrap:wrap;gap:.625rem;margin-top:1rem}.info-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .875rem;border-radius:10px;font-size:.875rem;font-weight:600;transition:all .2s ease;border:1.5px solid transparent}.info-chip svg{flex-shrink:0;opacity:.8}.info-chip span{line-height:1.2}.info-chip-language{background:linear-gradient(135deg,#6366f11a,#818cf826);color:#4f46e5;border-color:#6366f133}.info-chip-language:hover{background:linear-gradient(135deg,#6366f126,#818cf833);border-color:#6366f159;transform:translateY(-1px)}.info-chip-language svg{color:#6366f1}.info-chip-year{background:linear-gradient(135deg,#f59e0b1a,#fbbf2426);color:#b45309;border-color:#f59e0b33}.info-chip-year:hover{background:linear-gradient(135deg,#f59e0b26,#fbbf2433);border-color:#f59e0b59;transform:translateY(-1px)}.info-chip-year svg{color:#d97706}.info-chip-isbn{background:linear-gradient(135deg,#64748b14,#94a3b81f);color:#475569;border-color:#64748b33;font-family:SF Mono,Consolas,monospace;letter-spacing:.02em}.info-chip-isbn:hover{background:linear-gradient(135deg,#64748b1f,#94a3b82e);border-color:#64748b59;transform:translateY(-1px)}.info-chip-isbn svg{color:#64748b}.info-chip-subject{background:linear-gradient(135deg,#10b9811a,#34d39926);color:#047857;border-color:#10b98133}.info-chip-subject:hover{background:linear-gradient(135deg,#10b98126,#34d39933);border-color:#10b98159;transform:translateY(-1px)}.info-chip-subject svg{color:#10b981}.info-chip .user-select-all{-webkit-user-select:all;user-select:all;cursor:text}[dir=rtl] .book-info-chips{direction:rtl}@media(max-width:640px){.book-info-chips{gap:.5rem}.info-chip{padding:.4rem .75rem;font-size:.8rem;border-radius:8px}.info-chip svg{width:12px;height:12px}}.volume-info-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;background:linear-gradient(135deg,#8b5cf61f,#a855f714);border:1px solid rgba(139,92,246,.2);border-radius:6px;font-size:.75rem;font-weight:600;color:#7c3aed;margin-top:.25rem;width:fit-content}.volume-info-badge svg{flex-shrink:0;opacity:.8}.volume-info-badge span{letter-spacing:.01em}[data-theme=dark] .volume-info-badge{background:linear-gradient(135deg,#8b5cf633,#a855f726);border-color:#8b5cf659;color:#a78bfa}.library-setup-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:var(--bg-main)}.library-setup-card{width:100%;max-width:480px;background:#fff;border-radius:var(--radius-xl);padding:2.5rem;box-shadow:var(--shadow-lg);border:1px solid var(--border-subtle)}.library-setup-header{text-align:center;margin-bottom:2rem}.library-setup-icon{width:80px;height:80px;margin:0 auto 1.5rem;background:var(--brand-subtle);border-radius:20px;display:flex;align-items:center;justify-content:center;color:var(--brand)}.library-setup-header h1{font-size:1.75rem;margin-bottom:.5rem;color:var(--text-main)}.library-setup-header p{color:var(--text-muted);font-size:.95rem}.library-setup-form .form-group{margin-bottom:1.25rem}.library-setup-form label{display:block;font-size:.875rem;font-weight:600;color:var(--text-main);margin-bottom:.5rem}.library-setup-form input,.library-setup-form textarea{width:100%;padding:.875rem 1rem;border:1.5px solid var(--border-subtle);border-radius:var(--radius-md);font-family:inherit;font-size:.95rem;transition:all .2s}.library-setup-form input:focus,.library-setup-form textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-subtle)}.library-setup-error{padding:.875rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);color:#dc2626;font-size:.875rem;margin-bottom:1rem}.library-setup-submit{width:100%;padding:1rem 1.5rem;font-size:1rem}.library-selector{padding:0 1rem;margin-bottom:1rem;position:relative}.library-selector-single{pointer-events:none}.library-selector-single .library-selector-current{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#6366f114;border-radius:14px;color:var(--brand)}.library-selector-single .library-name{font-weight:700;font-size:.9rem}.library-selector-trigger{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:#fff;border:1.5px solid var(--border-subtle);border-radius:14px;font-family:inherit;font-size:.875rem;font-weight:700;color:var(--text-main);cursor:pointer;transition:all .2s}.library-selector-trigger:hover{border-color:var(--brand-light)}.library-selector-trigger .library-name{flex:1;text-align:start;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-selector-trigger .chevron{transition:transform .2s;color:var(--text-dim)}.library-selector-trigger .chevron.open{transform:rotate(180deg)}.library-selector-dropdown{position:absolute;top:100%;left:1rem;right:1rem;margin-top:.5rem;background:#fff;border:1px solid var(--border-subtle);border-radius:14px;box-shadow:0 10px 40px -10px #0003;z-index:100;overflow:hidden}.library-selector-header{padding:.75rem 1rem;font-size:.7rem;font-weight:800;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid var(--border-subtle);background:var(--bg-main)}.library-option{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%;padding:.875rem 1rem;border:none;background:transparent;text-align:start;cursor:pointer;transition:all .15s}.library-option:hover{background:var(--bg-main)}.library-option.selected{background:var(--brand-subtle)}.library-option-info{flex:1;min-width:0}.library-option-name{display:block;font-weight:600;font-size:.9rem;color:var(--text-main);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-option-description{display:block;font-size:.75rem;color:var(--text-muted);margin-top:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-option-meta{display:flex;align-items:center;gap:.5rem}.library-option .check-icon{color:var(--brand)}.library-role-badge{display:inline-flex;align-items:center;gap:.2rem;padding:.15rem .375rem;border-radius:4px;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.02em}.library-role-badge svg{width:10px;height:10px}.library-role-badge.role-admin{background:var(--brand-subtle);color:var(--brand)}.library-role-badge.role-editor{background:#22c55e1a;color:#16a34a}.library-role-badge.role-viewer{background:var(--bg-main);color:var(--text-muted)}.library-role-badge.role-superadmin{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;box-shadow:0 2px 4px #f59e0b4d}.library-management{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);overflow:hidden}.library-management-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-subtle);background:var(--bg-main)}.library-management-header h3{display:flex;align-items:center;gap:.75rem;font-size:1rem;font-weight:700;color:var(--text-main)}.library-management-header h3 svg{color:var(--brand)}.library-management-error{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;background:#ef444414;color:#dc2626;font-size:.875rem;border-bottom:1px solid rgba(239,68,68,.15)}.library-management-loading,.library-management-unauthorized{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem;color:var(--text-muted);text-align:center}.library-form{padding:1rem 1.5rem;background:var(--brand-subtle);border-bottom:1px solid var(--border-subtle)}.library-form-fields{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.library-form input{width:100%;padding:.75rem 1rem;border:1.5px solid var(--border-subtle);border-radius:var(--radius-md);font-family:inherit;font-size:.9rem;background:#fff;transition:all .2s}.library-form input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-subtle)}.library-form-actions{display:flex;gap:.5rem}.library-list{padding:.5rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.library-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem;color:var(--text-dim);text-align:center}.library-item{display:flex;flex-direction:column;gap:1rem;padding:1.25rem;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all .2s ease;height:100%}.library-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--brand-light)}.library-info{width:100%;flex:1}.library-name-row{display:flex;align-items:center;gap:.625rem;margin-bottom:.5rem}.library-name-row svg{color:var(--brand);flex-shrink:0}.library-name-row .library-name{font-weight:700;font-size:1rem;color:var(--text-main)}.library-info .library-description{display:block;font-size:.85rem;color:var(--text-muted);line-height:1.5;margin-left:0}.library-actions{display:flex;gap:.5rem;width:100%;justify-content:flex-end;border-top:1px solid var(--border-subtle);padding-top:1rem;margin-top:auto}.library-edit-form,.library-delete-confirm{width:100%;display:flex;flex-direction:column;gap:1rem}.library-edit-form .library-form-fields{display:flex;flex-direction:column;gap:.75rem;width:100%}.library-edit-form .library-form-fields input{width:100%;padding:.625rem .875rem;border:1.5px solid var(--border-subtle);border-radius:var(--radius-md);font-family:inherit;font-size:.9rem;font-weight:500;color:var(--text-main);background:#fff;transition:all .2s}.library-edit-form .library-form-fields input:first-child{max-width:none}.library-edit-form .library-form-fields input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-subtle)}.library-edit-form .library-form-fields input::placeholder{color:var(--text-dim);font-weight:400}.library-edit-form .library-form-actions{display:flex;justify-content:flex-end;gap:.5rem;width:100%}.library-delete-confirm{padding:0;background:transparent}.library-delete-confirm span{font-size:.9rem;color:#dc2626;text-align:center;margin-bottom:.5rem}.library-delete-confirm .library-form-actions{display:flex;justify-content:center;gap:.5rem;width:100%}.btn-icon{width:32px;height:32px;padding:0;border-radius:8px}.btn-ghost{background:transparent;border:none;color:var(--text-muted)}.btn-ghost:hover{background:var(--bg-main);color:var(--brand)}.btn-danger-ghost:hover{background:#ef44441a;color:#dc2626}.btn-danger{background:#dc2626;color:#fff;border-color:#dc2626}.btn-danger:hover{background:#b91c1c;border-color:#b91c1c}[data-theme=dark] .library-setup-card,[data-theme=dark] .library-management,[data-theme=dark] .library-selector-dropdown{background:var(--bg-card);border-color:var(--border-subtle)}[data-theme=dark] .library-selector-trigger,[data-theme=dark] .library-form input{background:var(--bg-main);border-color:var(--border-subtle);color:var(--text-main)}[data-theme=dark] .library-option:hover,[data-theme=dark] .library-item:hover{background:#ffffff0d}.libraries-settings-page{width:100%}.libraries-settings-page .library-management{width:100%;max-width:none}.library-item{display:flex;flex-direction:column;padding:1rem;border-radius:var(--radius-md);transition:background .15s}.library-item>.library-info,.library-item>.library-actions,.library-item>.library-edit-form,.library-item>.library-delete-confirm{display:flex;align-items:center}.library-item>.library-info{flex:1}.library-users-panel{width:100%;margin-top:1rem;padding-top:1rem;border-top:1px dashed var(--border-subtle)}.library-user-management{background:var(--bg-main);border-radius:var(--radius-md);padding:1rem}.library-users-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.library-users-header h4{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:700;color:var(--text-main);margin:0}.library-users-header h4 svg{color:var(--brand)}.library-users-header .user-count{font-size:.75rem;font-weight:600;color:var(--text-muted);padding:.25rem .625rem;background:#fff;border-radius:20px}.library-users-header .btn{margin-left:auto}.library-users-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#ef444414;color:#dc2626;font-size:.8rem;border-radius:var(--radius-sm);margin-bottom:1rem}.library-users-loading,.library-users-unauthorized{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem;color:var(--text-muted);text-align:center;font-size:.875rem}.library-users-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem;color:var(--text-dim);text-align:center}.library-users-empty svg{opacity:.4}.library-users-empty p{font-size:.875rem}.library-users-empty-note{padding:.75rem 1rem;background:#6366f10f;border-radius:var(--radius-sm);margin-bottom:1rem}.library-users-empty-note p{font-size:.8rem;color:var(--text-muted);margin:0}.library-add-user-form{padding:1rem;background:#fff;border-radius:var(--radius-md);border:1.5px solid var(--brand-light);margin-bottom:1rem}.add-user-fields{display:flex;gap:.75rem;margin-bottom:.75rem}.add-user-fields .user-select,.add-user-fields .role-select{flex:1;padding:.625rem .875rem;border:1.5px solid var(--border-subtle);border-radius:var(--radius-sm);font-family:inherit;font-size:.875rem;background:var(--bg-main);color:var(--text-main);cursor:pointer;transition:all .2s}.add-user-fields .user-select:focus,.add-user-fields .role-select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-subtle)}.add-user-fields .role-select{flex:0 0 120px}.add-user-actions{display:flex;gap:.5rem;justify-content:flex-end}.library-users-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.625rem}.library-user-item{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:#fff;border-radius:var(--radius-md);border:1px solid var(--border-subtle);transition:all .15s}.library-user-item:hover{border-color:var(--brand-light);background:linear-gradient(to bottom,white,var(--bg-main))}.user-info{display:flex;align-items:center;gap:.625rem;min-width:0}.user-avatar{width:36px;height:36px;border-radius:10px;object-fit:cover;flex-shrink:0}.user-avatar-sm{width:28px;height:28px;border-radius:8px;object-fit:cover;flex-shrink:0}.user-avatar-placeholder{width:36px;height:36px;border-radius:10px;background:var(--brand-subtle);color:var(--brand);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0}.user-info{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0;overflow:hidden}.user-avatar{width:28px;height:28px;border-radius:8px;object-fit:cover;flex-shrink:0}.user-avatar-sm{width:24px;height:24px;border-radius:6px;object-fit:cover;flex-shrink:0}.user-avatar-placeholder{width:28px;height:28px;border-radius:8px;background:var(--brand-subtle);color:var(--brand);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;flex-shrink:0}.user-details{display:flex;flex-direction:column;min-width:0;flex:1}.user-details .user-name{font-weight:700;font-size:.85rem;color:var(--text-main);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}.user-details .user-email{font-size:.7rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}.user-controls-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding-top:.375rem;border-top:1px dashed var(--border-subtle)}.user-role{display:flex;align-items:center;gap:.375rem;flex-shrink:0}.global-role-tag{font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--text-dim);padding:.125rem .3rem;background:var(--bg-main);border-radius:3px}.user-actions{display:flex;gap:.125rem;flex-shrink:0}.user-actions .btn-icon{width:26px;height:26px}.user-actions .btn-icon svg{width:12px;height:12px}.user-edit-role{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;width:100%;padding:.5rem;background:var(--brand-subtle);border-radius:var(--radius-sm);margin:-.25rem}.user-info-compact{display:flex;align-items:center;gap:.5rem;flex:1}.user-info-compact .user-name{font-weight:600;font-size:.875rem;color:var(--text-main)}.role-select-inline{padding:.5rem .75rem;border:1.5px solid var(--brand-light);border-radius:var(--radius-sm);font-family:inherit;font-size:.8rem;font-weight:600;background:#fff;cursor:pointer}.role-select-inline:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-subtle)}.edit-actions{display:flex;gap:.25rem}.user-revoke-confirm{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem .75rem;background:#ef44440f;border-radius:var(--radius-sm)}.user-revoke-confirm span{font-size:.8rem;color:#dc2626}.confirm-actions{display:flex;gap:.5rem}.btn-primary-ghost{background:transparent;border:none;color:var(--brand)}.btn-primary-ghost:hover,.btn-icon.active{background:var(--brand-subtle);color:var(--brand)}[data-theme=dark] .library-user-management{background:#ffffff08}[data-theme=dark] .library-add-user-form,[data-theme=dark] .library-user-item{background:var(--bg-card);border-color:var(--border-subtle)}[data-theme=dark] .add-user-fields .user-select,[data-theme=dark] .add-user-fields .role-select,[data-theme=dark] .role-select-inline{background:var(--bg-main);color:var(--text-main)}[data-theme=dark] .library-users-header .user-count{background:#ffffff14}[data-theme=dark] .user-avatar-placeholder{background:#6366f133}@media(max-width:640px){.add-user-fields{flex-direction:column}.add-user-fields .role-select{flex:1}.library-user-item{flex-wrap:wrap}.user-role{order:3;flex-basis:100%;margin-top:.5rem;padding-top:.5rem;border-top:1px dashed var(--border-subtle)}}
