*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--primary-50: #f5f3ff;--primary-100: #ede9fe;--primary-200: #ddd6fe;--primary-300: #c4b5fd;--primary-400: #a78bfa;--primary-500: #8b5cf6;--primary-600: #7c3aed;--primary-700: #6d28d9;--primary-800: #5b21b6;--primary-900: #4c1d95;--accent-400: #38bdf8;--accent-500: #0ea5e9;--accent-600: #0284c7;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--bg-base: #0a0a1a;--bg-surface: rgba(15, 15, 35, .8);--bg-elevated: rgba(25, 25, 55, .7);--bg-card: rgba(30, 30, 60, .5);--bg-hover: rgba(139, 92, 246, .08);--border-subtle: rgba(139, 92, 246, .12);--border-default: rgba(139, 92, 246, .2);--border-focus: rgba(139, 92, 246, .5);--text-primary: #f0eeff;--text-secondary: #a5a3c8;--text-muted: #6b6991;--glass-bg: rgba(20, 20, 45, .6);--glass-border: rgba(139, 92, 246, .15);--glass-shadow: 0 8px 32px rgba(0, 0, 0, .3);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px}html{font-size:15px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-base);color:var(--text-primary);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse 80% 60% at 10% 20%,rgba(139,92,246,.08) 0%,transparent 50%),radial-gradient(ellipse 60% 80% at 90% 80%,rgba(14,165,233,.06) 0%,transparent 50%),radial-gradient(ellipse 50% 50% at 50% 50%,rgba(139,92,246,.03) 0%,transparent 60%);pointer-events:none;z-index:0}#root{position:relative;z-index:1}.app-layout{display:flex;min-height:100vh}.sidebar{width:280px;min-height:100vh;background:var(--glass-bg);border-right:1px solid var(--glass-border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:2rem 1.25rem;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform var(--transition-normal)}.sidebar-logo{display:flex;align-items:center;gap:.75rem;padding-bottom:2rem;border-bottom:1px solid var(--border-subtle);margin-bottom:2rem}.sidebar-logo-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--primary-500),var(--accent-500));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#fff;box-shadow:0 4px 15px #8b5cf64d}.sidebar-logo h1{font-size:1.25rem;font-weight:700;background:linear-gradient(135deg,var(--primary-300),var(--accent-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.sidebar-logo span{font-size:.7rem;color:var(--text-muted);display:block;margin-top:2px;-webkit-text-fill-color:var(--text-muted)}.sidebar-nav{display:flex;flex-direction:column;gap:.35rem;flex:1}.sidebar-nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);font-size:.9rem;font-weight:500;transition:all var(--transition-fast);border:1px solid transparent;position:relative;overflow:hidden}.sidebar-nav-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:linear-gradient(180deg,var(--primary-400),var(--accent-400));border-radius:0 4px 4px 0;transition:height var(--transition-fast)}.sidebar-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-nav-item.active{background:#8b5cf61f;color:var(--primary-300);border-color:var(--border-subtle)}.sidebar-nav-item.active:before{height:60%}.sidebar-nav-item .icon{font-size:1.15rem;width:24px;text-align:center;flex-shrink:0}.sidebar-footer{margin-top:auto;padding-top:1.5rem;border-top:1px solid var(--border-subtle)}.sidebar-footer-text{font-size:.72rem;color:var(--text-muted);text-align:center;line-height:1.6}.main-content{flex:1;margin-left:280px;padding:2rem 2.5rem;min-height:100vh}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.page-header h2{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.page-header-actions{display:flex;gap:.75rem;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.25rem;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent;position:relative;overflow:hidden;white-space:nowrap}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.1),transparent);opacity:0;transition:opacity var(--transition-fast)}.btn:hover:after{opacity:1}.btn-primary{background:linear-gradient(135deg,var(--primary-600),var(--primary-700));color:#fff;box-shadow:0 4px 15px #8b5cf640}.btn-primary:hover{box-shadow:0 6px 20px #8b5cf659;transform:translateY(-1px)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-default)}.btn-secondary:hover{border-color:var(--primary-400);background:#8b5cf61a}.btn-danger{background:#ef444426;color:#fca5a5;border-color:#ef444433}.btn-danger:hover{background:#ef444440;border-color:#ef444466}.btn-ghost{background:transparent;color:var(--text-secondary);padding:.5rem}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-sm{padding:.4rem .8rem;font-size:.78rem}.btn-icon{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:2rem}.stat-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:1.5rem;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:all var(--transition-normal);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.stat-card:nth-child(1):before{background:linear-gradient(90deg,var(--primary-500),var(--primary-400))}.stat-card:nth-child(2):before{background:linear-gradient(90deg,var(--accent-500),var(--accent-400))}.stat-card:nth-child(3):before{background:linear-gradient(90deg,var(--success),#4ade80)}.stat-card:nth-child(4):before{background:linear-gradient(90deg,var(--warning),#fbbf24)}.stat-card:hover{transform:translateY(-2px);border-color:var(--border-default);box-shadow:var(--glass-shadow)}.stat-card-icon{width:42px;height:42px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:1rem}.stat-card:nth-child(1) .stat-card-icon{background:#8b5cf626;color:var(--primary-400)}.stat-card:nth-child(2) .stat-card-icon{background:#0ea5e926;color:var(--accent-400)}.stat-card:nth-child(3) .stat-card-icon{background:#22c55e26;color:var(--success)}.stat-card:nth-child(4) .stat-card-icon{background:#f59e0b26;color:var(--warning)}.stat-card-value{font-size:2rem;font-weight:800;letter-spacing:-.03em;line-height:1;margin-bottom:.35rem}.stat-card-label{font-size:.8rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.search-filter-bar{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap;align-items:stretch}.search-box{flex:1;min-width:250px;position:relative}.search-box .search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:1rem;pointer-events:none}.search-box input{width:100%;padding:.75rem 1rem .75rem 2.75rem;background:var(--glass-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:.88rem;font-family:Inter,sans-serif;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all var(--transition-fast)}.search-box input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #8b5cf61a}.search-box input::placeholder{color:var(--text-muted)}.filter-select{min-width:170px}.filter-select select{width:100%;padding:.75rem 2.25rem .75rem 1rem;background:var(--glass-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:.85rem;font-family:Inter,sans-serif;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;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='%236b6991' 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 .75rem center;transition:all var(--transition-fast)}.filter-select select:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #8b5cf61a}.filter-select select option{background:#1a1a3a;color:var(--text-primary)}.table-container{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);overflow:hidden;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--glass-shadow)}.book-table{width:100%;border-collapse:collapse}.book-table thead{background:#8b5cf60f}.book-table th{padding:1rem 1.25rem;text-align:left;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-subtle);cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition-fast);white-space:nowrap}.book-table th:hover{color:var(--primary-400)}.book-table th .sort-icon{margin-left:.35rem;font-size:.7rem;opacity:.5}.book-table th.sorted .sort-icon{opacity:1;color:var(--primary-400)}.book-table td{padding:.9rem 1.25rem;font-size:.88rem;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);transition:background var(--transition-fast)}.book-table tr:hover td{background:var(--bg-hover)}.book-table tr:last-child td{border-bottom:none}.book-table td:first-child{color:var(--text-primary);font-weight:500}.book-table .actions-cell{text-align:right;white-space:nowrap}.book-table .actions-cell .btn-icon{opacity:0;transition:opacity var(--transition-fast)}.book-table tr:hover .actions-cell .btn-icon{opacity:1}.table-empty{text-align:center;padding:4rem 2rem}.table-empty-icon{font-size:3.5rem;margin-bottom:1rem;opacity:.4}.table-empty h3{font-size:1.15rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.table-empty p{color:var(--text-muted);font-size:.88rem;max-width:360px;margin:0 auto;line-height:1.6}.table-footer{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;background:#8b5cf608;border-top:1px solid var(--border-subtle);font-size:.8rem;color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal{background:linear-gradient(145deg,#14142dfa,#0f0f23fa);border:1px solid var(--glass-border);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 60px #00000080;animation:slideUp .3s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.75rem 1rem}.modal-header h3{font-size:1.2rem;font-weight:700;letter-spacing:-.01em}.modal-body{padding:.5rem 1.75rem 1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.75rem 1.5rem;border-top:1px solid var(--border-subtle)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.04em}.form-group input,.form-group textarea{width:100%;padding:.75rem 1rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;font-family:Inter,sans-serif;transition:all var(--transition-fast)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #8b5cf61a;background:#1e1e3ccc}.form-group input::placeholder{color:var(--text-muted)}.import-section{margin-bottom:2rem}.import-dropzone{border:2px dashed var(--border-default);border-radius:var(--radius-lg);padding:3rem 2rem;text-align:center;background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;transition:all var(--transition-normal);position:relative}.import-dropzone:hover,.import-dropzone.drag-over{border-color:var(--primary-400);background:#8b5cf60d;transform:translateY(-2px);box-shadow:var(--glass-shadow)}.import-dropzone-icon{font-size:2.5rem;color:var(--primary-400);margin-bottom:1rem}.import-dropzone h3{font-size:1.05rem;font-weight:600;margin-bottom:.5rem}.import-dropzone p{font-size:.82rem;color:var(--text-muted)}.import-dropzone input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.column-mapping{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:1.5rem;margin-top:1.5rem}.column-mapping h4{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.mapping-row{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem}.mapping-row label{flex:0 0 120px;font-size:.82rem;font-weight:500;color:var(--text-secondary)}.mapping-row select{flex:1;padding:.6rem 1rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;font-family:Inter,sans-serif;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;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='%236b6991' 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 .75rem center;transition:all var(--transition-fast)}.mapping-row select:focus{outline:none;border-color:var(--border-focus)}.mapping-row select option{background:#1a1a3a}.confirm-text{text-align:center;padding:1rem 0;color:var(--text-secondary);font-size:.95rem;line-height:1.6}.confirm-text strong{color:var(--text-primary)}.pagination{display:flex;align-items:center;gap:.35rem}.pagination-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:transparent;color:var(--text-secondary);font-size:.8rem;font-family:Inter,sans-serif;cursor:pointer;transition:all var(--transition-fast)}.pagination-btn:hover:not(:disabled){border-color:var(--primary-400);color:var(--primary-300);background:var(--bg-hover)}.pagination-btn.active{background:var(--primary-600);border-color:var(--primary-600);color:#fff}.pagination-btn:disabled{opacity:.3;cursor:not-allowed}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:999px;font-size:.72rem;font-weight:600}.badge-purple{background:#8b5cf626;color:var(--primary-300)}.badge-blue{background:#0ea5e926;color:var(--accent-400)}.notification-badge{position:absolute;top:-2px;right:-2px;width:8px;height:8px;background:var(--primary-500);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#8b5cf633;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#8b5cf659}.owner-tag{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .65rem;background:#8b5cf61a;border:1px solid rgba(139,92,246,.15);border-radius:999px;font-size:.78rem;font-weight:500;color:var(--primary-300)}.read-toggle{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none;padding:.5rem 0}.toggle-switch{width:44px;height:24px;background:#6464824d;border-radius:999px;position:relative;transition:all var(--transition-normal);border:1px solid var(--border-subtle);flex-shrink:0}.toggle-switch.active{background:#22c55e4d;border-color:#22c55e66}.toggle-knob{width:18px;height:18px;background:var(--text-muted);border-radius:50%;position:absolute;top:2px;left:2px;transition:all var(--transition-normal)}.toggle-switch.active .toggle-knob{left:22px;background:var(--success);box-shadow:0 0 8px #22c55e66}.read-label{color:var(--success);font-size:.88rem;font-weight:500}.unread-label{color:var(--text-muted);font-size:.88rem;font-weight:500}.read-status-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .7rem;border-radius:999px;font-size:.76rem;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;border:1px solid;transition:all var(--transition-fast);white-space:nowrap}.read-status-btn.is-read{background:#22c55e1f;color:#4ade80;border-color:#22c55e33}.read-status-btn.is-read:hover{background:#22c55e33;border-color:#22c55e59}.read-status-btn.is-unread{background:#f59e0b1a;color:#fbbf24;border-color:#f59e0b33}.read-status-btn.is-unread:hover{background:#f59e0b33;border-color:#f59e0b59}.read-status-btn.is-reading{background:#3b82f61f;color:#60a5fa;border-color:#3b82f633}.read-status-btn.is-reading:hover{background:#3b82f633;border-color:#3b82f659}.stat-card:nth-child(5):before{background:linear-gradient(90deg,var(--accent-500),var(--primary-400))}.stat-card:nth-child(5) .stat-card-icon{background:#0ea5e91f;color:var(--accent-400)}.stat-card:nth-child(6):before{background:linear-gradient(90deg,#ec4899,#f472b6)}.stat-card:nth-child(6) .stat-card-icon{background:#ec48991f;color:#f472b6}.status-selector{display:flex;gap:.5rem}.status-option{flex:1;padding:.6rem .5rem;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-elevated);color:var(--text-muted);font-size:.82rem;font-weight:500;font-family:Inter,sans-serif;cursor:pointer;transition:all var(--transition-fast);text-align:center}.status-option:hover{border-color:var(--border-default);color:var(--text-secondary)}.status-option.active.unread{background:#f59e0b1f;border-color:#f59e0b4d;color:#fbbf24}.status-option.active.reading{background:#3b82f61f;border-color:#3b82f64d;color:#60a5fa}.status-option.active.read{background:#22c55e1f;border-color:#22c55e4d;color:#4ade80}.mobile-menu-btn{position:fixed;top:1rem;left:1rem;z-index:200;width:42px;height:42px;border-radius:var(--radius-md);background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--text-primary);font-size:1.2rem;cursor:pointer;display:none;align-items:center;justify-content:center;transition:all var(--transition-fast)}@media(max-width:768px){.mobile-menu-btn{display:flex}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding:4rem 1.25rem 1.25rem}.page-header{flex-direction:column;align-items:flex-start}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.search-filter-bar{flex-direction:column}.search-box{min-width:unset}.book-table{font-size:.82rem}.book-table th,.book-table td{padding:.65rem .75rem}.modal{max-width:100%;border-radius:var(--radius-lg)}}.quote-card{display:flex;align-items:center;gap:1.5rem;padding:1.75rem 2rem;background:linear-gradient(135deg,#1e1e3c66,#0f0f2366);border:1px solid var(--glass-border);border-radius:var(--radius-lg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);margin-bottom:2rem;transition:all var(--transition-normal);position:relative;overflow:hidden}.quote-card:after{content:'"';position:absolute;top:-10px;right:20px;font-size:8rem;font-family:serif;color:var(--primary-500);opacity:.1;pointer-events:none}.quote-card:hover{transform:translateY(-2px);border-color:var(--primary-500);box-shadow:0 12px 40px #0006}.quote-icon{font-size:2.5rem;color:var(--primary-400);flex-shrink:0;opacity:.8}.quote-content{flex:1}.quote-text{font-size:1.15rem;line-height:1.6;font-style:italic;color:var(--text-primary);margin-bottom:.5rem;font-weight:500}.quote-author{font-size:.85rem;color:var(--primary-300);font-weight:600;letter-spacing:.05em;text-transform:uppercase}@media(max-width:640px){.quote-card{flex-direction:column;text-align:center;gap:1rem;padding:1.5rem}}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.row-enter{animation:rowEnter .3s ease-out}@keyframes rowEnter{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}
