@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&family=Newsreader:ital,wght@0,400;0,500;1,400&display=swap");:root{--bg:#fafaf8;--bg-elevated:#fff;--bg-hover:#f4f4f2;--bg-active:#eeeee9;--text-primary:#1a1a1a;--text-secondary:#6b6b6b;--text-tertiary:#9b9b9b;--border:#e4e4e0;--border-subtle:#ececea;--accent:#2d2d2d;--accent-hover:#404040;--accent-soft:#f0f0ee;--danger:#c4553d;--danger-bg:#fdf0ed;--success:#2d7d46;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--shadow-sm:0 1px 2px rgba(0,0,0,.04);--shadow-md:0 2px 8px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);--shadow-lg:0 8px 24px rgba(0,0,0,.08),0 2px 8px rgba(0,0,0,.04);--font-body:"Plus Jakarta Sans",-apple-system,sans-serif;--font-display:"Newsreader",Georgia,serif;--transition:180ms cubic-bezier(0.4,0,0.2,1)}*{margin:0;padding:0;box-sizing:border-box}body,html{height:100%;font-family:var(--font-body);background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{text-align:center;max-width:380px;width:100%}.login-icon{width:48px;height:48px;margin:0 auto 32px;border-radius:var(--radius-md);background:var(--accent);display:flex;align-items:center;justify-content:center}.login-title{font-family:var(--font-display);font-size:28px;font-weight:500;letter-spacing:-.02em;margin-bottom:8px}.login-subtitle{font-size:15px;color:var(--text-secondary);line-height:1.5;margin-bottom:40px}.login-btn{display:inline-flex;align-items:center;gap:10px;padding:12px 28px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:14px;font-weight:600;cursor:pointer;transition:background var(--transition),transform var(--transition)}.login-btn:hover{background:var(--accent-hover);transform:translateY(-1px)}.login-btn:active{transform:translateY(0)}.login-btn svg{width:18px;height:18px}.login-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.config-error{margin-top:32px;padding:16px 20px;background:var(--danger-bg);border-radius:var(--radius-md);font-size:13px;color:var(--danger);line-height:1.5;text-align:left}.config-error code{background:rgba(0,0,0,.06);padding:2px 5px;border-radius:3px;font-size:12px}.login-features{text-align:left;margin-bottom:24px;gap:12px}.login-feature,.login-features{display:flex;flex-direction:column}.login-feature{gap:2px;font-size:14px}.login-feature strong{color:var(--text-primary);font-weight:600;font-size:13px}.login-feature span{color:var(--text-secondary);font-size:13px;line-height:1.4}.login-data-notice{text-align:left;font-size:12px;color:var(--text-tertiary);line-height:1.5;padding:12px 14px;background:var(--accent-soft);border-radius:var(--radius-sm);margin-bottom:28px}.login-data-notice a,.login-data-notice strong{color:var(--text-secondary)}.login-data-notice a{text-decoration:underline}.login-footer{margin-top:32px;display:flex;align-items:center;gap:8px;justify-content:center;font-size:12px;color:var(--text-tertiary)}.login-footer a{color:var(--text-tertiary);text-decoration:none}.login-footer a:hover{color:var(--text-secondary);text-decoration:underline}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:260px;min-width:260px;background:var(--bg);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;padding:16px 0;z-index:100}.sidebar-header{gap:10px;padding:4px 20px 20px}.sidebar-header,.sidebar-logo{display:flex;align-items:center}.sidebar-logo{width:28px;height:28px;border-radius:var(--radius-sm);background:var(--accent);justify-content:center;flex-shrink:0}.sidebar-brand{font-family:var(--font-display);font-size:17px;font-weight:500;letter-spacing:-.01em;flex:1 1}.sidebar-close-btn{display:none;padding:4px;background:none;border:none;cursor:pointer;color:var(--text-tertiary);border-radius:var(--radius-sm)}.sidebar-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);padding:16px 20px 8px}.sidebar-lists{flex:1 1;overflow-y:auto;padding:0 8px}.sidebar-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;color:var(--text-secondary);transition:all var(--transition);border:none;background:none;width:100%;text-align:left;font-family:var(--font-body)}.sidebar-item:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-item.active{background:var(--bg-active);color:var(--text-primary);font-weight:500}.sidebar-item-icon{width:16px;height:16px;opacity:.5;flex-shrink:0}.sidebar-item.active .sidebar-item-icon{opacity:.8}.sidebar-item-text{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-item-count{font-size:11px;color:var(--text-tertiary);font-weight:500;min-width:18px;text-align:right}.sidebar-item-actions{display:flex;gap:2px;opacity:0;transition:opacity var(--transition)}.sidebar-item:hover .sidebar-item-actions{opacity:1}.sidebar-item-action{padding:2px;background:none;border:none;cursor:pointer;color:var(--text-tertiary);border-radius:3px;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.sidebar-item-action:hover{background:var(--bg-hover);color:var(--text-secondary)}.sidebar-item-action.danger:hover{background:var(--danger-bg);color:var(--danger)}.sidebar-add-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;margin:4px 8px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;color:var(--text-tertiary);transition:all var(--transition);border:1px dashed var(--border);background:none;width:calc(100% - 16px);font-family:var(--font-body)}.sidebar-add-btn:hover{color:var(--text-secondary);border-color:var(--text-tertiary);background:var(--bg-hover)}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border-subtle);margin-top:8px}.user-section{display:flex;align-items:center;gap:10px;padding:6px}.user-avatar{object-fit:cover}.user-avatar,.user-avatar-fallback{width:30px;height:30px;border-radius:50%}.user-avatar-fallback{background:var(--accent-soft);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--text-secondary)}.user-info{flex:1 1;min-width:0}.user-name{font-size:13px;font-weight:500}.user-email,.user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email{font-size:11px}.signout-btn,.user-email{color:var(--text-tertiary)}.signout-btn{padding:4px;background:none;border:none;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);display:flex;align-items:center;justify-content:center}.signout-btn:hover{background:var(--bg-hover);color:var(--danger)}.new-list-input{font-family:var(--font-body);font-size:14px;padding:8px 12px;border:1px solid var(--accent);border-radius:var(--radius-sm);outline:none;width:calc(100% - 16px);margin:4px 8px;background:var(--bg-elevated);box-shadow:0 0 0 3px rgba(45,45,45,.06)}.main-content{flex:1 1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-elevated)}.main-header{padding:32px 40px 0;display:flex;align-items:flex-start;gap:12px}.mobile-menu-btn{display:none;padding:6px;background:none;border:none;cursor:pointer;color:var(--text-secondary);border-radius:var(--radius-sm);margin-top:4px;flex-shrink:0}.mobile-menu-btn:hover{background:var(--bg-hover)}.main-header-text{flex:1 1}.main-title{font-family:var(--font-display);font-size:26px;font-weight:500;letter-spacing:-.02em;margin-bottom:4px}.main-subtitle{font-size:13px;color:var(--text-tertiary)}.task-input-wrapper{padding:20px 40px}.task-input-container{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition)}.task-input-container:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(45,45,45,.06)}.task-input{flex:1 1;border:none;background:none;font-family:var(--font-body);font-size:14px;color:var(--text-primary);outline:none;min-width:0}.task-input::placeholder{color:var(--text-tertiary)}.task-input-date{padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:12px;color:var(--text-secondary);background:var(--bg-elevated);cursor:pointer;outline:none;transition:border-color var(--transition)}.task-input-date:focus{border-color:var(--accent)}.task-add-btn{padding:6px 14px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition);white-space:nowrap}.task-add-btn:hover{background:var(--accent-hover)}.task-add-btn:disabled{opacity:.4;cursor:not-allowed}.task-list-area{flex:1 1;overflow-y:auto;padding:0 40px 40px}.task-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border-subtle);animation:taskEnter .25s cubic-bezier(.4,0,.2,1);transition:opacity var(--transition)}.task-item.optimistic-hide{opacity:.4}@keyframes taskEnter{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.task-item:last-child{border-bottom:none}.task-checkbox-wrapper{padding-top:2px;flex-shrink:0}.task-checkbox{width:18px;height:18px;border:1.5px solid var(--border);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);background:transparent;outline:none}.task-checkbox:hover{border-color:var(--accent);background:var(--accent-soft)}.task-checkbox:focus-visible{box-shadow:0 0 0 2px var(--accent)}.task-checkbox.checked{border-color:var(--success);background:var(--success)}.task-checkbox.checked svg{opacity:1}.task-checkbox svg{width:10px;height:10px;opacity:0;transition:opacity var(--transition);color:#fff}.task-body{flex:1 1;min-width:0}.task-title{font-size:14px;line-height:1.4;color:var(--text-primary);word-break:break-word}.task-item.completed .task-title{text-decoration:line-through;color:var(--text-tertiary)}.task-notes{font-size:13px;margin-top:2px;line-height:1.4}.task-due,.task-notes{color:var(--text-tertiary)}.task-due{font-size:11px;margin-top:4px;display:inline-flex;align-items:center;gap:4px}.task-due.overdue{color:var(--danger)}.task-actions{display:flex;gap:2px;opacity:0;transition:opacity var(--transition);flex-shrink:0;padding-top:2px}.task-item:hover .task-actions{opacity:1}@media (hover:none){.sidebar-item-actions,.task-actions{opacity:1}}.task-action-btn{padding:4px;background:none;border:none;cursor:pointer;color:var(--text-tertiary);border-radius:var(--radius-sm);transition:all var(--transition);display:flex;align-items:center;justify-content:center}.task-action-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.task-action-btn.delete:hover{background:var(--danger-bg);color:var(--danger)}.show-completed-toggle{display:flex;align-items:center;gap:8px;padding:8px 0;cursor:pointer;font-size:13px;color:var(--text-tertiary);border:none;background:none;font-family:var(--font-body);transition:color var(--transition)}.show-completed-toggle:hover{color:var(--text-secondary)}.show-completed-toggle svg{transition:transform var(--transition)}.show-completed-toggle.open svg{transform:rotate(90deg)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-tertiary)}.empty-state-icon{width:48px;height:48px;margin:0 auto 16px;opacity:.3}.empty-state h3{font-family:var(--font-display);font-size:18px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.empty-state p{font-size:14px}.skeleton-item{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--border-subtle)}.skeleton-circle{width:18px;height:18px;border-radius:50%;background:var(--bg-hover);animation:pulse 1.5s ease-in-out infinite}.skeleton-lines{flex:1 1;display:flex;flex-direction:column;gap:6px}.skeleton-line{height:12px;border-radius:4px;background:var(--bg-hover);animation:pulse 1.5s ease-in-out infinite}.skeleton-line.short{width:40%}.skeleton-line.medium{width:70%}.skeleton-line.long{width:90%}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center}.spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.3);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-elevated);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:440px;animation:modalIn .2s cubic-bezier(.4,0,.2,1)}@keyframes modalIn{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{padding:20px 24px 0;font-family:var(--font-display);font-size:18px;font-weight:500;letter-spacing:-.01em}.modal-body{padding:16px 24px}.modal-field{margin-bottom:14px}.modal-field:last-child{margin-bottom:0}.modal-label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary);margin-bottom:6px}.modal-input,.modal-textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:14px;color:var(--text-primary);background:var(--bg);outline:none;transition:border-color var(--transition)}.modal-input:focus,.modal-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(45,45,45,.06)}.modal-textarea{resize:vertical;min-height:72px;line-height:1.5}.modal-date-row{display:flex;align-items:center;gap:8px}.modal-date-row input{flex:1 1}.modal-date-clear{padding:6px 10px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:12px;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition);white-space:nowrap}.modal-date-clear:hover{border-color:var(--danger);color:var(--danger)}.modal-footer{padding:12px 24px 20px;display:flex;justify-content:flex-end;gap:8px}.modal-btn{padding:8px 18px;border:none;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition)}.modal-btn-secondary{background:var(--bg);color:var(--text-secondary);border:1px solid var(--border)}.modal-btn-secondary:hover{background:var(--bg-hover)}.modal-btn-primary{background:var(--accent);color:#fff}.modal-btn-primary:hover{background:var(--accent-hover)}.modal-btn-danger{background:var(--danger);color:#fff}.modal-btn-danger:hover{opacity:.9}.confirm-text{font-size:14px;color:var(--text-secondary);line-height:1.5;padding:4px 0}.toast-container{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:300;display:flex;flex-direction:column;gap:8px;align-items:center}.toast{padding:10px 20px;border-radius:var(--radius-md);font-size:13px;font-weight:500;box-shadow:var(--shadow-lg);animation:toastIn .3s cubic-bezier(.4,0,.2,1);white-space:nowrap}.toast.error{background:var(--danger);color:#fff}.toast.success{background:var(--success);color:#fff}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.inline-edit-input{font-family:var(--font-body);font-size:14px;padding:4px 8px;border:1px solid var(--accent);border-radius:var(--radius-sm);outline:none;width:100%;background:var(--bg-elevated);box-shadow:0 0 0 3px rgba(45,45,45,.06)}.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:90}@media (max-width:768px){.sidebar{position:fixed;top:0;left:0;bottom:0;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lg)}.sidebar.open{transform:translateX(0)}.sidebar-close-btn{display:flex}.mobile-overlay.visible{display:block}.mobile-menu-btn{display:flex}.main-header{padding:24px 20px 0}.task-input-wrapper{padding:16px 20px}.task-list-area{padding:0 20px 20px}.task-input-date{display:none}}@media (max-width:420px){.main-header{padding:20px 16px 0}.task-input-wrapper{padding:12px 16px}.task-list-area{padding:0 16px 16px}}