body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.notification-container{display:flex;flex-direction:column;gap:.75rem;max-width:400px;pointer-events:none;position:fixed;right:1rem;top:1rem;z-index:10000}.notification{align-items:center;animation:slideIn .3s ease-out;background:#fff;border-left:4px solid;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;gap:.75rem;padding:1rem 1.25rem;pointer-events:all;transition:var(--transition-fast)}.notification.updated{animation:pulse .4s ease;transform:scale(1.02)}@keyframes slideIn{0%{opacity:0;transform:translateX(400px)}to{opacity:1;transform:translateX(0)}}.notification-icon{align-items:center;display:flex;flex-shrink:0;font-size:1.25rem;font-weight:700;height:24px;justify-content:center;width:24px}.notification-message{color:var(--text-primary);flex:1 1;font-size:.9375rem;line-height:1.5}.notification-close{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;display:flex;flex-shrink:0;font-size:1.25rem;height:24px;justify-content:center;padding:0;transition:var(--transition-bg);width:24px}.notification-close:hover{background:#0000000d}.notification-success{border-left-color:var(--color-success)}.notification-success .notification-icon{color:var(--color-success)}.notification-error{border-left-color:#f44336}.notification-error .notification-icon{color:#f44336}.notification-warning{border-left-color:var(--color-warning)}.notification-warning .notification-icon{color:var(--color-warning)}.notification-info{border-left-color:#2196f3}.notification-info .notification-icon{color:#2196f3}@media (max-width:600px){.notification-container{left:1rem;max-width:none;right:1rem}}.sync-status{animation:slideUp .3s ease-out;background:var(--gradient-primary);border-radius:var(--radius-lg);bottom:1rem;box-shadow:0 4px 20px #667eea4d;color:#fff;max-width:400px;padding:1rem 1.25rem;position:fixed;right:1rem;z-index:9999}@keyframes slideUp{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.sync-status-offline{background:linear-gradient(135deg,var(--color-warning) 0,#f57c00 100%)}.sync-status-content{align-items:center;display:flex;gap:.75rem}.sync-status-icon{animation:pulse 2s ease-in-out infinite;font-size:1.5rem}.sync-status-text{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.sync-status-text strong{font-size:.9375rem;font-weight:600}.sync-status-text span{font-size:.8125rem;opacity:.9}.sync-status-actions{display:flex;flex-direction:column;gap:.5rem}.sync-status-cancel,.sync-status-force{background:#fff3;border:1px solid #ffffff4d;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:.75rem;font-weight:500;min-width:80px;padding:.5rem .75rem;transition:var(--transition-fast);white-space:nowrap}.sync-status-cancel{background:#dc3545cc;border-color:#dc3545e6}.sync-status-cancel:hover:not(:disabled){background:#c82333e6}.sync-status-force:hover:not(:disabled){background:#ffffff4d}.sync-status-cancel:disabled,.sync-status-force:disabled{cursor:not-allowed;opacity:.6}@media (max-width:600px){.sync-status{left:1rem;max-width:none;right:1rem}.sync-status-content{flex-wrap:wrap}.sync-status-actions{flex-direction:row;width:100%}.sync-status-cancel,.sync-status-force{flex:1 1}}.loading-container{color:var(--text-medium);font-size:18px}.error-boundary,.loading-container{align-items:center;display:flex;justify-content:center;min-height:100vh}.error-boundary{background:var(--gradient-primary);padding:2rem}.error-boundary-content{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-overlay);max-width:600px;padding:3rem;text-align:center;width:100%}.error-boundary-icon{font-size:4rem;margin-bottom:1rem}.error-boundary-title{color:var(--text-primary);font-size:2rem;margin:0 0 1rem}.error-boundary-message{color:var(--text-medium);font-size:1.1rem;line-height:1.6;margin:0 0 2rem}.error-boundary-details{background:var(--bg-light);border:1px solid var(--border-color);border-radius:var(--radius);margin:2rem 0;padding:1rem;text-align:left}.error-boundary-details summary{color:var(--text-medium);cursor:pointer;font-weight:600;padding:.5rem}.error-boundary-details summary:hover{color:var(--text-heading)}.error-boundary-stack{margin-top:1rem}.error-boundary-stack h3{color:var(--text-medium);font-size:.9rem;letter-spacing:.5px;margin:1rem 0 .5rem;text-transform:uppercase}.error-boundary-stack pre{background:#fff;border:1px solid var(--color-danger-border);border-radius:var(--radius-sm);color:#d32f2f;font-size:.85rem;overflow-x:auto;padding:1rem;white-space:pre-wrap;word-break:break-word}.error-boundary-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.error-boundary-button{border:none;border-radius:var(--radius);cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:var(--transition-fast)}.error-boundary-button.primary{background:var(--color-primary);color:#fff}.error-boundary-button.primary:hover{background:#5568d3;box-shadow:var(--shadow-primary);transform:translateY(-2px)}.error-boundary-button.secondary{background:var(--bg-light);color:var(--text-medium)}.error-boundary-button.secondary:hover{background:var(--border-color);color:var(--text-heading)}@media (max-width:480px){.error-boundary-content{padding:2rem 1.5rem}.error-boundary-title{font-size:1.5rem}.error-boundary-message{font-size:1rem}.error-boundary-actions{flex-direction:column}.error-boundary-button{width:100%}}:root{--gradient-primary:linear-gradient(135deg,#37676e,#764ba2);--color-primary:#667eea;--color-primary-light:#a8b3ff;--color-success:#4caf50;--color-success-dark:#2e7d32;--color-success-bg:#e8f5e9;--color-warning:#ff9800;--color-warning-dark:#e65100;--color-warning-bg:#fff3e0;--color-warning-border:#ffe0b2;--color-danger:#c62828;--color-danger-bg:#ffebee;--color-danger-border:#ffcdd2;--color-danger-bright:#ff5722;--color-info-bg:#e3f2fd;--text-primary:#212121;--text-heading:#333;--text-dark:#424242;--text-body:#555;--text-secondary:#616161;--text-medium:#666;--text-cool:#6b7280;--text-tertiary:#757575;--text-subtle:#9ca3af;--text-hint:#999;--text-disabled:#9e9e9e;--border-dark:#ccc;--border-medium:#ddd;--border-color:#e0e0e0;--border-light:#eee;--bg-light:#f5f5f5;--bg-subtle:#f9f9f9;--bg-page:#fafafa;--shadow-xs:0 2px 4px #0000001a;--shadow-sm:0 2px 8px #00000014;--shadow-md:0 2px 8px #0000001a;--shadow-primary:0 4px 12px #667eea66;--shadow-lg:0 4px 20px #00000026;--shadow-overlay:0 20px 60px #0000004d;--radius-sm:4px;--radius-md:6px;--radius:8px;--radius-lg:12px;--radius-xl:16px;--transition-snappy:all 0.15s;--transition-fast:all 0.2s;--transition-bg:background 0.2s}*{box-sizing:border-box}.app{background:linear-gradient(135deg,#37676e,#764ba2);background:var(--gradient-primary);min-height:100vh}.app-header{background:#fffffff2;box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow-md);padding:1.5rem 0;position:-webkit-sticky;position:sticky;top:0;width:100%;z-index:100}.app-header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 2rem}.header-content{gap:1.5rem}.header-content,.logo{align-items:center;display:flex}.logo{gap:.75rem}.logo-icon{font-size:2rem}.logo h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#37676e,#764ba2);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-size:1.75rem;margin:0}.subtitle{border-left:2px solid #e0e0e0;border-left:2px solid var(--border-color);color:#616161;color:var(--text-secondary);font-size:.875rem;margin:0;padding-left:1.5rem}.main-content{margin:0 auto;max-width:1400px;padding:2rem}.page-header-wrapper{background:#0000;padding:2rem 2rem 0;width:100%}.page-header{background:#fff;border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow-md);margin:0 auto;max-width:calc(1400px - 4rem);padding:2rem}.page-header-top{align-items:flex-start;display:flex;gap:2rem;justify-content:space-between;margin-bottom:1rem}.header-actions{display:flex;gap:.75rem}.browse-button,.calendar-button,.search-button{background:#fff;border:2px solid #667eea;border:2px solid var(--color-primary);border-radius:8px;border-radius:var(--radius);color:#667eea;color:var(--color-primary);cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s;transition:var(--transition-fast);white-space:nowrap}.browse-button:hover,.calendar-button:hover,.search-button:hover{background:#667eea;background:var(--color-primary);box-shadow:0 4px 12px #667eea66;box-shadow:var(--shadow-primary);color:#fff;transform:translateY(-2px)}.add-item-button{background:linear-gradient(135deg,#37676e,#764ba2);background:var(--gradient-primary);border:none;border-radius:8px;border-radius:var(--radius);color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s;transition:var(--transition-fast);white-space:nowrap}.add-item-button:hover{box-shadow:0 4px 12px #667eea66;box-shadow:var(--shadow-primary);transform:translateY(-2px)}.task-count{background:linear-gradient(135deg,#37676e,#764ba2);background:var(--gradient-primary);border-radius:8px;border-radius:var(--radius);color:#fff;display:inline-block;font-weight:600;padding:.5rem 1rem}.task-count-row{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.filter-sort-controls{align-items:center;display:flex;gap:.75rem}.task-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,300px);justify-content:start}.task-grid-virtual-container{margin:0 auto;max-width:1400px;padding:2rem;width:100%}.task-grid-virtual-container .task-card{width:300px}.task-list-grouped{display:flex;flex-direction:column;gap:2rem}.task-group-header{align-items:center;border-bottom:2px solid #ffffff26;display:flex;gap:.5rem;margin-bottom:.75rem;padding:.5rem 0}.task-group-icon{font-size:1.25rem}.task-group-title{color:#fff;font-size:1.1rem;font-weight:600;margin:0}.task-group-description{color:#ffffff80;font-size:.85rem;margin-left:auto}.task-group-overdue .task-group-header{border-bottom-color:#f44336}.task-group-dueSoon .task-group-header{border-bottom-color:#ff9800;border-bottom-color:var(--color-warning)}.task-group-upcoming .task-group-header{border-bottom-color:#2196f3}.task-group-recentlyCompleted .task-group-header{border-bottom-color:#4caf50;border-bottom-color:var(--color-success)}.task-list-empty{color:#ffffffb3;padding:3rem 2rem;text-align:center}.task-list-empty-icon{display:block;font-size:3rem;margin-bottom:1rem}.error,.loading{color:#fff;font-size:1.25rem;padding:4rem 2rem;text-align:center}.error{color:#ffcdd2;color:var(--color-danger-border)}@media (max-width:768px){.header-content{align-items:flex-start;flex-direction:column;gap:.5rem}.header-user-section{align-items:flex-end;flex-direction:column;gap:.5rem}.username-display{font-size:.75rem}.subtitle{border-left:none;padding-left:0}.page-header-top{flex-direction:column;gap:1rem}.header-actions{flex-wrap:wrap;width:100%}.add-item-button,.browse-button,.calendar-button,.search-button{flex:1 1;font-size:.875rem;min-width:120px;padding:.625rem 1rem}.task-count-row{align-items:stretch;flex-direction:column}.filter-sort-controls{justify-content:space-between;width:100%}.filter-button{flex:1 1}.task-grid{grid-template-columns:1fr}.task-grid-virtual-container .task-card{width:100%}.main-content{padding:1rem}.page-header{padding:1.5rem}}.header-user-section{align-items:center;display:flex;gap:1rem}.username-display{color:#667eea;color:var(--color-primary);font-size:.875rem;font-weight:500}.logout-button{background:#667eea;background:var(--color-primary);border:1px solid #667eea;border:1px solid var(--color-primary);border-radius:6px;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s;transition:var(--transition-fast)}.logout-button:hover{background:#764ba2;border-color:#764ba2}.logo.clickable{cursor:pointer}.filter-button{align-items:center;background:#fff;border:2px solid #667eea;border:2px solid var(--color-primary);border-radius:8px;border-radius:var(--radius);color:#667eea;color:var(--color-primary);cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.5rem 1rem;transition:all .2s;transition:var(--transition-fast);white-space:nowrap}.filter-button:hover{background:#667eea;background:var(--color-primary);box-shadow:0 4px 12px #667eea66;box-shadow:var(--shadow-primary);color:#fff;transform:translateY(-2px)}.filter-button.filter-active{animation:pulse 2s ease-in-out 1;background:linear-gradient(135deg,#f093fb,#f5576c);border-color:#f5576c;color:#fff}@keyframes pulse{0%,to{box-shadow:0 4px 12px #667eea4d}50%{box-shadow:0 4px 20px #f5576c80}}.clear-filters-inline{background:#fff;border:2px solid #667eea;border:2px solid var(--color-primary);border-radius:6px;border-radius:var(--radius-md);box-shadow:0 3px 6px #00000026;color:#667eea;color:var(--color-primary);cursor:pointer;font-size:.875rem;font-weight:700;margin-left:.75rem;padding:.35rem .85rem;text-shadow:0 0 1px #667eea4d;transition:all .2s;transition:var(--transition-fast)}.clear-filters-inline:hover{background:#667eea;background:var(--color-primary);box-shadow:0 4px 8px #667eea4d;color:#fff;transform:translateY(-1px)}.sort-menu{display:inline-block;position:relative}.sort-dropdown{background:#fff;border-radius:8px;border-radius:var(--radius);box-shadow:0 4px 20px #00000026;box-shadow:var(--shadow-lg);margin-top:4px;min-width:220px;overflow:hidden;position:absolute;right:0;top:100%;z-index:100}.sort-option{align-items:center;background:#fff;border:none;color:#424242;color:var(--text-dark);cursor:pointer;display:flex;font-size:.875rem;gap:8px;padding:10px 14px;text-align:left;transition:background .15s;width:100%}.sort-option:hover{background:#f5f5f5;background:var(--bg-light)}.sort-option.active{background:#e8eaf6;color:#667eea;color:var(--color-primary);font-weight:600}.sort-option-icon{font-size:1rem}.sort-option-label{flex:1 1}.sort-check{color:#667eea;color:var(--color-primary);font-weight:700}.hidden-completed-note{color:#dedede;font-size:.8125rem;font-style:italic;margin-left:.5rem}.no-tasks{background:#ffffffeb;border:1px solid #0000000f;border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 12px 30px #0000001f;color:#2f2f2f;grid-column:1/-1;margin:0 auto;max-width:720px;padding:3rem 1rem;text-align:center}.no-tasks h3{color:#1f1f1f;margin-bottom:.75rem}.no-tasks p{font-size:1.125rem;margin-bottom:1rem}.btn-primary{background:linear-gradient(135deg,#37676e,#764ba2);background:var(--gradient-primary);border:none;border-radius:8px;border-radius:var(--radius);color:#fff;cursor:pointer;font-size:.9375rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s;transition:var(--transition-fast)}.btn-primary:hover{box-shadow:0 4px 12px #667eea4d;transform:translateY(-2px)}
/*# sourceMappingURL=main.171418f3.css.map*/