*{margin:0;padding:0;box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-base: #0f172a;--bg-surface: #1e293b;--bg-elevated: #334155;--bg-hover: #475569;--bg-primary: var(--bg-base);--bg-secondary: var(--bg-surface);--bg-tertiary: var(--bg-elevated);--bg-active: var(--bg-hover);--bg-input: #0f172a;--surface-primary: var(--bg-surface);--surface-secondary: var(--bg-elevated);--surface-elevated: var(--bg-hover);--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-tertiary: #64748b;--text-muted: #475569;--text-inverse: #0f172a;--border-primary: #334155;--border-secondary: #475569;--border-focus: #3b82f6;--border-hover: #64748b;--accent-primary: #3b82f6;--accent-primary-hover: #2563eb;--accent-secondary: #60a5fa;--accent-light: #93c5fd;--accent-muted: rgba(59, 130, 246, .15);--success: #22c55e;--success-muted: rgba(34, 197, 94, .15);--warning: #f59e0b;--warning-muted: rgba(245, 158, 11, .15);--error: #ef4444;--error-muted: rgba(239, 68, 68, .15);--danger: #ef4444;--info: #3b82f6;--info-muted: rgba(59, 130, 246, .15);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 2px 8px rgba(0, 0, 0, .4);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .5);--shadow-xl: 0 8px 32px rgba(0, 0, 0, .6);--font-xs: .6875rem;--font-sm: .75rem;--font-base: .875rem;--font-md: .9375rem;--font-lg: 1rem;--font-xl: 1.125rem;--font-2xl: 1.25rem;--font-3xl: 1.5rem;--spacing-xs: .125rem;--spacing-sm: .25rem;--spacing-md: .5rem;--spacing-lg: .75rem;--spacing-xl: 1rem;--spacing-2xl: 1.5rem;--spacing-3xl: 2rem;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-2xl: 16px;--transition-fast: .1s ease;--transition-base: .15s ease;--transition-slow: .25s ease;color:var(--text-primary);background-color:var(--bg-base)}body{margin:0;min-width:320px;min-height:100vh}#root{height:100vh;overflow:hidden}button{font-family:inherit;cursor:pointer;transition:all .2s}button:focus{outline:none}a{color:var(--accent-primary);text-decoration:none}a:hover{color:var(--accent-secondary);text-decoration:underline}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-surface);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:4px;border:2px solid var(--bg-surface)}::-webkit-scrollbar-thumb:hover{background:var(--bg-hover)}::-webkit-scrollbar-corner{background:var(--bg-surface)}*{scrollbar-width:thin;scrollbar-color:var(--border-secondary) var(--bg-surface)}.auth-status{padding:6px;border-top:1px solid #2a2a2a;margin-top:auto;z-index:10000}.auth-user{display:flex;flex-direction:column;gap:4px}.user-email{font-size:10px;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-bottom:5px}.login-btn,.logout-btn{width:100%;padding:2px 6px;border:none;border-radius:3px;font-weight:500;cursor:pointer;transition:all .15s;font-size:9px;line-height:1.2;min-height:18px}.login-btn{background:#2563eb;color:#fff}.login-btn:hover{background:#1d4ed8}.logout-btn{background:#ef4444;color:#fff}.logout-btn:hover{background:#dc2626}.auth-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.auth-modal{background:#fff;padding:2rem;border-radius:12px;max-width:400px;width:90%;position:relative;box-shadow:0 10px 40px #0003}.auth-modal h2{margin:0 0 1.5rem;color:#1a1a1a}.auth-modal form{display:flex;flex-direction:column;gap:1rem}.auth-modal input{padding:.75rem;border:1px solid #e0e0e0;border-radius:6px;font-size:1rem}.auth-modal input:focus{outline:none;border-color:#2563eb}.error-message{background:#fee2e2;color:#dc2626;padding:.75rem;border-radius:6px;font-size:.9rem}.auth-submit-btn{padding:.75rem;background:#2563eb;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s ease}.auth-submit-btn:hover{background:#1d4ed8}.toggle-mode-btn{margin-top:1rem;background:none;border:none;color:#2563eb;cursor:pointer;font-size:.9rem;text-decoration:underline}.close-modal-btn{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;color:#999;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.close-modal-btn:hover{background:#f0f0f0;color:#333}@media (prefers-color-scheme: dark){.auth-status{border-top-color:#404040}.user-email{color:#a0a0a0}.auth-modal{background:#1a1a1a}.auth-modal h2{color:#fff}.auth-modal input{background:#2a2a2a;border-color:#404040;color:#fff}.close-modal-btn:hover{background:#2a2a2a}}.file-uploader-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000}.file-uploader-modal{background:var(--bg-surface);border-radius:12px;width:90%;max-width:600px;max-height:80vh;overflow:hidden;box-shadow:0 8px 32px #00000080;border:1px solid var(--border-primary)}.file-uploader-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-primary);background:var(--bg-base)}.file-uploader-header h2{margin:0;font-size:20px;color:var(--text-primary);font-weight:600}.file-uploader-header .close-btn{background:none;border:none;font-size:28px;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.file-uploader-header .close-btn:hover{background:var(--bg-surface);color:var(--text-primary)}.file-uploader-content{padding:24px}.file-drop-zone{border:2px dashed var(--border-primary);border-radius:8px;padding:60px 40px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg-base)}.file-drop-zone:hover{border-color:var(--accent-primary);background:var(--bg-surface)}.file-drop-zone.dragging{border-color:var(--accent-primary);background:var(--bg-elevated);transform:scale(1.02)}.drop-zone-icon{font-size:48px;margin-bottom:16px}.drop-zone-text{font-size:16px;color:var(--text-primary);margin:0 0 8px;font-weight:500}.drop-zone-hint{font-size:13px;color:var(--text-secondary);margin:0}.file-upload-error{margin-top:16px;padding:12px 16px;background:var(--error-bg);border:1px solid var(--error);border-radius:6px;color:var(--error);display:flex;align-items:center;gap:8px;font-size:14px}.error-icon{font-size:18px}.file-upload-progress{text-align:center;padding:40px 20px}.progress-icon{font-size:64px;margin-bottom:16px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.file-upload-progress h3{margin:0 0 24px;color:var(--text-primary);font-size:20px;font-weight:600}.progress-bar-container{width:100%;height:8px;background:var(--bg-elevated);border-radius:4px;overflow:hidden;margin-bottom:12px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-primary-hover));border-radius:4px;transition:width .3s ease}.progress-text{font-size:14px;color:var(--text-secondary);margin:0}.notification-settings{background:var(--bg-surface);border-radius:12px;padding:24px;max-width:500px;margin:0 auto}.notification-settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.notification-settings-header h2{margin:0;font-size:20px;color:var(--text-primary)}.notification-settings-header .close-btn{background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.notification-settings-header .close-btn:hover{color:var(--text-primary);background:var(--bg-elevated)}.notification-warning{background:var(--error-bg);border:1px solid var(--error);color:var(--error);padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.notification-description{color:var(--text-secondary);font-size:14px;margin-bottom:16px}.notification-section{padding:20px 0;border-bottom:1px solid var(--border-primary)}.notification-section:last-child{border-bottom:none}.notification-section h3{margin:0 0 8px;font-size:16px;font-weight:600;color:var(--text-primary)}.section-description{color:var(--text-secondary);font-size:13px;margin:0 0 16px}.toggle-row{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:8px 0;user-select:none}.toggle-row span:first-child{color:var(--text-primary);font-size:14px}.toggle-row input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.toggle-slider{position:relative;width:44px;height:24px;background:var(--bg-elevated);border-radius:12px;transition:all .3s}.toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:var(--text-primary);border-radius:50%;transition:all .3s}.toggle-row input:checked+.toggle-slider{background:var(--accent-primary)}.toggle-row input:checked+.toggle-slider:after{transform:translate(20px)}.options-container{margin-top:16px;padding-left:0}.option-label{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.options-grid{display:flex;flex-wrap:wrap;gap:8px}.option-btn{padding:8px 14px;background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s}.option-btn:hover{border-color:var(--accent-primary);color:var(--text-primary)}.option-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.enable-btn{background:var(--accent-primary);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.enable-btn:hover{background:var(--accent-primary-hover)}.test-btn{background:transparent;color:var(--accent-primary);border:1px solid var(--accent-primary);padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.test-btn:hover{background:var(--accent-primary);color:#fff}.notification-settings-modal{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.notification-settings-modal .notification-settings{max-height:90vh;overflow-y:auto}.book-lookup-overlay{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.book-lookup-modal{background:#1a1a2e;border:1px solid #333;border-radius:12px;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000080}.book-lookup-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #333}.book-lookup-header h2{margin:0;font-size:1.25rem;color:#e0e0e0}.book-lookup-header .close-btn{background:transparent;border:none;color:#888;font-size:1.25rem;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.book-lookup-header .close-btn:hover{background:#333;color:#fff}.book-lookup-search{padding:1rem 1.25rem;border-bottom:1px solid #333}.search-type-toggle{display:flex;gap:.5rem;margin-bottom:.75rem}.toggle-btn{flex:1;padding:.5rem;background:#2a2a3e;border:1px solid #404040;border-radius:6px;color:#888;font-size:.85rem;cursor:pointer;transition:all .2s}.toggle-btn:hover{background:#333;border-color:#555}.toggle-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.search-input-row{display:flex;gap:.5rem}.book-lookup-search .search-input{flex:1;padding:.75rem 1rem;background:#2a2a3e;border:1px solid #404040;border-radius:6px;color:#e0e0e0;font-size:.95rem}.book-lookup-search .search-input:focus{outline:none;border-color:#3b82f6}.book-lookup-search .search-input::placeholder{color:#666}.search-btn{padding:.75rem 1rem;background:#3b82f6;border:none;border-radius:6px;color:#fff;font-size:1rem;cursor:pointer;transition:all .2s}.search-btn:hover:not(:disabled){background:#2563eb}.search-btn:disabled{opacity:.5;cursor:not-allowed}.book-lookup-error{padding:.75rem 1.25rem;background:#ef44441a;color:#ef4444;font-size:.9rem;border-bottom:1px solid #333}.book-lookup-results{flex:1;overflow-y:auto;padding:.5rem}.loading-state{text-align:center;padding:2rem;color:#888}.empty-state{text-align:center;padding:3rem 2rem;color:#666}.empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-state p{margin:.25rem 0}.empty-state .hint{font-size:.85rem;color:#555}.empty-state .skip-btn{margin-top:1rem;padding:.5rem 1rem;background:#2a2a3e;border:1px solid #404040;border-radius:6px;color:#888;font-size:.9rem;cursor:pointer;transition:all .2s}.empty-state .skip-btn:hover{background:#333;border-color:#3b82f6;color:#e0e0e0}.results-list{display:flex;flex-direction:column;gap:.5rem}.book-result{display:flex;gap:1rem;padding:1rem;background:#2a2a3e;border:1px solid #404040;border-radius:8px;cursor:pointer;transition:all .2s}.book-result:hover{background:#333;border-color:#3b82f6;transform:translateY(-1px)}.book-thumbnail{flex-shrink:0;width:60px;height:90px;background:#1a1a2e;border-radius:4px;overflow:hidden;display:flex;align-items:center;justify-content:center}.book-thumbnail img{width:100%;height:100%;object-fit:cover}.no-thumbnail{font-size:2rem;color:#555}.book-info{flex:1;min-width:0}.book-title{font-size:1rem;font-weight:600;color:#e0e0e0;margin-bottom:.25rem;line-height:1.3}.book-subtitle{font-size:.85rem;color:#888;margin-bottom:.25rem;font-style:italic}.book-author{font-size:.9rem;color:#8ab4f8;margin-bottom:.5rem}.book-meta{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.8rem;color:#666}.book-meta span:not(:last-child):after{content:"•";margin-left:.5rem}.book-isbn{font-size:.75rem;color:#555;margin-top:.25rem;font-family:monospace}.book-lookup-results::-webkit-scrollbar{width:8px}.book-lookup-results::-webkit-scrollbar-track{background:#1a1a2e}.book-lookup-results::-webkit-scrollbar-thumb{background:#404040;border-radius:4px}.book-lookup-results::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width: 640px){.book-lookup-modal{width:95%;max-height:90vh}.book-result{padding:.75rem}.book-thumbnail{width:50px;height:75px}}.source-form-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.source-form-modal{background:var(--bg-base);border-radius:12px;width:90%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;border:1px solid var(--bg-surface);box-shadow:0 20px 40px #00000080}.source-form-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--bg-surface)}.source-form-header h2{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.source-form-header .close-btn{background:none;border:none;color:var(--text-muted);font-size:24px;cursor:pointer;padding:4px;line-height:1}.source-form-header .close-btn:hover{color:var(--text-primary)}.source-form-error{margin:16px 20px 0;padding:12px;background:#ef44441a;border-radius:8px;color:var(--error);font-size:14px}.source-form-content{flex:1;overflow-y:auto;padding:20px}.source-form-field{margin-bottom:20px}.source-form-field label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.source-form-field input,.source-form-field textarea{width:100%;background:var(--bg-surface);border:1px solid var(--bg-elevated);border-radius:8px;padding:12px 16px;font-size:15px;color:var(--text-primary);transition:border-color .2s}.source-form-field input:focus,.source-form-field textarea:focus{outline:none;border-color:var(--accent-primary)}.source-form-field input::placeholder,.source-form-field textarea::placeholder{color:var(--text-muted)}.source-form-field textarea{min-height:100px;resize:vertical}.source-form-footer{display:flex;gap:12px;padding:16px 20px;border-top:1px solid var(--bg-surface)}.source-form-footer .cancel-btn{flex:1;padding:12px;border-radius:8px;border:none;background:var(--bg-surface);color:var(--text-muted);font-size:15px;font-weight:500;cursor:pointer;transition:background .2s}.source-form-footer .cancel-btn:hover:not(:disabled){background:var(--bg-surface)}.source-form-footer .create-btn{flex:1;padding:12px;border-radius:8px;border:none;background:var(--accent-primary);color:var(--text-primary);font-size:15px;font-weight:600;cursor:pointer;transition:background .2s,opacity .2s}.source-form-footer .create-btn:hover:not(:disabled){background:var(--accent-primary-hover)}.source-form-footer .create-btn:disabled{opacity:.5;cursor:not-allowed}.sidebar{width:180px;min-width:150px;max-width:400px;height:100vh;background-color:var(--bg-base);border-right:1px solid var(--border-secondary);display:flex;flex-direction:column;overflow:hidden;position:relative;z-index:1000;transition:width .3s ease}.sidebar.collapsed{width:60px!important;min-width:60px}.sidebar-resize-handle{position:absolute;top:0;right:0;width:4px;height:100%;cursor:ew-resize;background:transparent;z-index:1000;transition:background .2s}.sidebar-resize-handle:hover,.sidebar-resize-handle.resizing{background:var(--accent-secondary)}.sidebar-header{padding:.5rem 1rem;border-bottom:1px solid var(--border-secondary);background:var(--bg-base);display:flex;justify-content:space-between;align-items:center}.sidebar.collapsed .sidebar-header{padding:.5rem;justify-content:center}.sidebar.collapsed .sidebar-brand{justify-content:center}.sidebar.collapsed .sidebar-header-actions{position:absolute;top:.5rem;right:.5rem}.sidebar-brand{display:flex;align-items:center;gap:.5rem}.sidebar-logo{width:24px;height:24px;border-radius:50%}.sidebar-header h1{font-size:14px;font-weight:600;margin:0;color:var(--text-primary)}.sidebar-header-actions{display:flex;gap:.5rem;align-items:center}.search-btn{background:transparent;border:1px solid var(--border-secondary);color:var(--text-secondary);cursor:pointer;padding:.4rem .6rem;border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center}.search-btn:hover{background:#8ab4f81a;border-color:var(--accent-secondary);color:var(--accent-secondary)}.close-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:0;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-btn:hover{color:var(--text-primary)}.sidebar-nav{padding:4px 6px;background:var(--bg-base);display:flex;flex-direction:column;gap:8px}.nav-section{display:flex;flex-direction:column;gap:1px}.nav-section-title{font-size:9px;font-weight:600;color:var(--text-muted);text-transform:uppercase;padding:4px 8px 2px;letter-spacing:.5px;cursor:pointer;display:flex;align-items:center;gap:4px;transition:all .15s;-webkit-user-select:none;user-select:none;border-radius:2px}.nav-section-title:hover{color:var(--text-primary);background:var(--bg-elevated)}.collapse-icon{font-size:7px;transition:transform .2s ease;display:inline-block;width:10px;text-align:center}.nav-link{width:100%;padding:5px 8px;background:transparent;border:none;border-radius:3px;font-size:11px;cursor:pointer;transition:all .15s;text-align:left;color:var(--text-secondary);font-weight:500;display:flex;align-items:center;gap:.5rem}.nav-link:hover{background:var(--bg-elevated);color:var(--text-primary)}.sidebar.collapsed .nav-link{justify-content:center;padding:8px 4px;gap:0}.nav-link.today-btn-highlight{background:linear-gradient(135deg,#667eea,#764ba2);color:var(--text-primary);font-weight:600;box-shadow:0 2px 4px #667eea4d;display:flex;align-items:center;gap:.5rem}.nav-link.today-btn-highlight:hover{background:linear-gradient(135deg,#7c8ef0,#8a5ab8);color:var(--text-primary);transform:translateY(-1px);box-shadow:0 4px 8px #667eea66}.daily-calendar-icon{flex-shrink:0;color:currentColor}.nav-link.today-btn-highlight .daily-calendar-icon{filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.sidebar-actions{position:absolute;bottom:3.25rem;width:100%;padding:10px;background:var(--bg-base);margin-top:auto}.btn-primary{width:100%;padding:0 4px;background-color:transparent;color:var(--text-secondary);border:1px solid var(--bg-elevated);border-radius:2px;font-size:7px;font-weight:400;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:2px;line-height:1;height:20px}.btn-primary:hover{background-color:var(--bg-elevated);color:var(--text-primary);border-color:var(--accent-primary-hover)}.sidebar.collapsed .btn-primary{font-size:20px;height:36px;padding:8px}.sidebar.collapsed .sidebar-nav{overflow-y:auto}.sidebar.collapsed .nav-section{gap:2px}.type-selector-overlay{position:fixed;inset:0;z-index:9999}.type-selector{background:var(--bg-surface);border:1px solid var(--border-secondary);border-radius:8px;box-shadow:0 4px 12px #00000080;padding:.5rem;display:flex;flex-direction:column;gap:.25rem;max-height:400px;overflow-y:auto!important;overflow-x:hidden;z-index:10000}.type-selector::-webkit-scrollbar{width:6px}.type-selector::-webkit-scrollbar-track{background:var(--bg-base);border-radius:3px}.type-selector::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:3px}.type-selector::-webkit-scrollbar-thumb:hover{background:var(--bg-hover)}.type-category{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;margin:.5rem 0 .25rem;letter-spacing:.5px}.type-category:first-child{margin-top:0}.type-selector button{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;background:var(--bg-elevated);border:1px solid transparent;border-radius:4px;text-align:left;cursor:pointer;transition:all .2s;color:var(--text-primary);font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.type-selector button span:first-child{flex-shrink:0;font-size:1rem;line-height:1;display:inline-block}.type-selector button:hover{background:var(--bg-hover);border-color:var(--accent-secondary)}.search-overlay{position:fixed;inset:0;background:#000000b3;z-index:9998;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.search-modal{position:fixed;top:20%;left:50%;transform:translate(-50%);width:90%;max-width:600px;background:var(--bg-surface);border:1px solid var(--border-secondary);border-radius:12px;box-shadow:0 8px 32px #0009;z-index:9999;display:flex;flex-direction:column;max-height:70vh}.search-modal-header{padding:1rem;border-bottom:1px solid var(--border-secondary);display:flex;gap:.5rem;align-items:center}.search-modal-input{flex:1;background:var(--bg-elevated);border:1px solid var(--border-secondary);border-radius:6px;padding:.75rem 1rem;color:var(--text-primary);font-size:1rem;outline:none;transition:all .2s}.search-modal-input:focus{border-color:var(--accent-secondary);background:var(--bg-hover)}.search-modal-input::placeholder{color:var(--text-muted)}.search-modal-close{width:40px;height:40px;background:transparent;border:1px solid var(--border-secondary);border-radius:6px;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.search-modal-close:hover{background:#f28b821a;border-color:var(--error);color:var(--error)}.search-modal-results{flex:1;overflow-y:auto;padding:.5rem}.search-loading,.search-empty{padding:2rem;text-align:center;color:var(--text-secondary);font-size:.9rem}.search-results-header{padding:.5rem 1rem;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.search-result-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:6px;cursor:pointer;transition:all .2s;margin-bottom:.25rem}.search-result-item:hover{background:var(--bg-elevated)}.search-result-icon{font-size:1.5rem;flex-shrink:0}.search-result-content{flex:1;min-width:0}.search-result-name{font-size:.95rem;color:var(--text-primary);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-meta{font-size:.75rem;color:var(--text-muted);display:flex;align-items:center;gap:.5rem}.search-result-type{background:#8ab4f826;color:var(--accent-secondary);padding:.15rem .5rem;border-radius:3px;text-transform:capitalize;font-weight:500}.search-result-date{color:var(--text-muted)}.search-tips{padding:2rem;color:var(--text-secondary)}.search-tip-title{font-size:.85rem;font-weight:600;margin-bottom:.75rem;color:var(--text-primary)}.search-tips ul{list-style:none;padding:0;margin:0}.search-tips li{padding:.5rem 0;font-size:.85rem;color:var(--text-secondary)}.search-tips kbd{background:var(--bg-elevated);border:1px solid var(--border-secondary);border-radius:3px;padding:.15rem .4rem;font-family:monospace;font-size:.8rem;color:var(--accent-secondary)}.search-modal-results::-webkit-scrollbar{width:8px}.search-modal-results::-webkit-scrollbar-track{background:var(--bg-surface)}.search-modal-results::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:4px}.search-modal-results::-webkit-scrollbar-thumb:hover{background:var(--bg-hover)}.source-type-selector-overlay{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000}.source-type-selector-modal{background:var(--bg-base);border:1px solid var(--border-primary);border-radius:12px;width:90%;max-width:500px;box-shadow:0 8px 32px #00000080}.source-type-selector-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-primary)}.source-type-selector-header h2{margin:0;font-size:1.1rem;color:var(--text-primary)}.source-type-selector-header .close-btn{background:transparent;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:0;line-height:1;transition:color .2s}.source-type-selector-header .close-btn:hover{color:var(--text-primary)}.source-type-selector-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;padding:1rem}.source-type-option{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1rem .75rem;background:var(--bg-elevated);border:1px solid var(--border-secondary);border-radius:8px;cursor:pointer;transition:all .2s;text-align:center}.source-type-option:hover{background:var(--bg-hover);border-color:var(--accent-primary);transform:translateY(-2px)}.source-type-icon{font-size:1.75rem}.source-type-label{font-size:.95rem;font-weight:600;color:var(--text-primary)}.source-type-desc{font-size:.75rem;color:var(--text-secondary);line-height:1.3}@media (max-width: 480px){.source-type-selector-grid{grid-template-columns:1fr}.source-type-option{flex-direction:row;gap:.75rem;text-align:left}.source-type-icon{font-size:1.5rem}}.sidebar-user{position:absolute;bottom:3.25rem;width:calc(100% - 20px);padding:8px 10px;background:var(--bg-base);border-top:1px solid var(--border-secondary);margin:0 10px}.user-admin-btn{width:100%;padding:8px 12px;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:.75rem;font-size:13px}.user-admin-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar.collapsed .user-admin-btn{justify-content:center;padding:8px}.sidebar.collapsed .user-admin-btn span{display:none}.sortable-nav-item{display:flex;align-items:center;gap:.25rem;position:relative}.nav-drag-handle{display:flex;align-items:center;justify-content:center;padding:.25rem;background:none;border:none;color:var(--text-tertiary);cursor:grab;opacity:0;transition:opacity .2s;flex-shrink:0}.sortable-nav-item:hover .nav-drag-handle{opacity:1}.nav-drag-handle:active{cursor:grabbing}.sidebar.collapsed .nav-drag-handle{display:none}.sync-status{position:fixed;bottom:16px;right:840px;z-index:1100;display:flex;gap:6px;align-items:center}.sync-status-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;box-shadow:0 2px 8px #0000004d;cursor:pointer;font-size:10px;font-weight:500;color:#e0e0e0;transition:all .15s}.sync-status-btn:hover:not(:disabled){background:#2a2a2a;border-color:#2563eb}.sync-status-btn:disabled{opacity:.5;cursor:not-allowed}.sync-status-btn.offline{border-color:#ffc107;background:#2a2a1a}.sync-status-btn.failed{border-color:#dc3545;background:#2a1a1a}.sync-status-btn.auth-issue{border-color:#f59e0b;background:#2a2a1a;animation:pulse-auth 2s ease-in-out infinite}@keyframes pulse-auth{0%,to{box-shadow:0 2px 8px #f59e0b4d}50%{box-shadow:0 2px 16px #f59e0b99}}.sync-status-btn.syncing .sync-icon,.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sync-icon{font-size:12px;line-height:1;display:inline-flex;align-items:center}.sync-text{font-size:10px}.clear-queue-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#dc3545;border:1px solid #c82333;border-radius:4px;box-shadow:0 2px 8px #dc35454d;cursor:pointer;font-size:12px;transition:all .15s}.clear-queue-btn:hover{background:#c82333;border-color:#bd2130}.sync-actions{position:relative}.sync-menu-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:4px;box-shadow:0 2px 8px #0000004d;cursor:pointer;font-size:12px;transition:all .15s;z-index:1101}.sync-menu-btn:hover{background:#2a2a2a;border-color:#3a3a3a}.sync-menu{position:absolute;bottom:100%;right:0;margin-bottom:8px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;box-shadow:0 4px 16px #0006;overflow:hidden;min-width:160px;z-index:1102}.sync-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:transparent;border:none;color:#e0e0e0;font-size:12px;text-align:left;cursor:pointer;transition:background .15s}.sync-menu-item:hover{background:#2a2a2a}.sync-menu-item.danger{color:#f87171}.sync-menu-item.danger:hover{background:#2a1a1a}@media (max-width: 768px){.sync-status{bottom:60px;right:16px}.sync-status-btn{padding:4px 6px;font-size:9px}.sync-icon{font-size:11px}}.app-footer{position:fixed;bottom:0;left:0;right:0;height:30px;background:var(--bg-surface);border-top:1px solid var(--border-primary);display:flex;align-items:center;justify-content:flex-end;padding:0 16px;z-index:900;box-shadow:0 -2px 8px #0003}.app-footer .sync-status{position:static;bottom:auto;right:auto}.main-content{padding-bottom:40px}@media (prefers-color-scheme: dark){.app-footer{background:var(--bg-surface);border-top-color:var(--border-primary)}}@media (max-width: 768px){.app-footer{height:48px}.main-content{padding-bottom:48px}}.celebration-overlay{position:fixed;inset:0;z-index:10000;pointer-events:auto;cursor:pointer}.celebration-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.celebration-message{position:absolute;top:35%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 32px;background:var(--bg-elevated);border:1px solid var(--border-secondary);border-radius:12px;box-shadow:0 8px 32px #0006;animation:celebration-pop .4s cubic-bezier(.175,.885,.32,1.275) forwards;pointer-events:none}.celebration-small{border-color:var(--accent-primary)}.celebration-medium{border-color:var(--warning, #f59e0b)}.celebration-big{border-color:#ffd93d;box-shadow:0 0 40px #ffd93d4d,0 8px 32px #0006}.celebration-emoji{font-size:36px;line-height:1}.celebration-big .celebration-emoji{font-size:48px}.celebration-text{font-size:14px;font-weight:600;color:var(--text-primary);text-align:center;max-width:280px;line-height:1.4}.celebration-big .celebration-text{font-size:16px;max-width:320px}@keyframes celebration-pop{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.app{display:flex;height:100vh;overflow:hidden}.main-content{flex:1;background-color:var(--bg-base);overflow-y:auto;transition:margin-left .3s ease;padding-bottom:40px}.main-content.with-sidebar,.main-content.full-width{margin-left:0}.sidebar-toggle-btn{position:fixed;top:10px;left:10px;z-index:999;width:36px;height:36px;background:var(--bg-base);border:1px solid var(--bg-elevated);border-radius:6px;color:var(--text-secondary);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 2px 8px #0000004d}.sidebar-toggle-btn:hover{background:var(--bg-surface);border-color:var(--accent-secondary);color:var(--accent-secondary);transform:scale(1.05)}
