*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh;padding:20px}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.todo-form{margin-bottom:2rem}.form-group{align-items:stretch;display:flex;gap:.75rem}.todo-input{background:#fff;border:2px solid #e5e7eb;border-radius:8px;flex:1 1;font-size:1rem;padding:.875rem 1rem;transition:all .2s ease}.todo-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.todo-input:disabled{background-color:#f9fafb;color:#9ca3af;cursor:not-allowed}.todo-input::placeholder{color:#9ca3af}.add-btn{min-width:100px;padding:.875rem 1.5rem;transition:all .2s ease;white-space:nowrap}.add-btn:disabled{cursor:not-allowed;opacity:.6}.loading-text{animation:pulse 1.5s ease-in-out infinite;display:inline-block}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (max-width:640px){.form-group{flex-direction:column}.add-btn{min-width:auto}}.todo-item{align-items:center;background:#fff;border-left:4px solid #667eea;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;justify-content:space-between;margin-bottom:.75rem;padding:1rem;transition:all .2s ease}.todo-item:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-1px)}.todo-item.completed{border-left-color:#10b981;opacity:.8}.todo-item.loading{opacity:.6;pointer-events:none}.todo-content{align-items:center;display:flex;flex:1 1;gap:.75rem;min-width:0}.todo-checkbox{border:2px solid #d1d5db;border-radius:4px;cursor:pointer;flex-shrink:0;height:1.25rem;transition:all .2s ease;width:1.25rem}.todo-checkbox:checked{background-color:#667eea;border-color:#667eea}.todo-checkbox:focus{box-shadow:0 0 0 3px #667eea1a;outline:none}.todo-title{color:#374151;cursor:pointer;font-size:1rem;line-height:1.4;transition:color .2s ease;word-break:break-word}.todo-item.completed .todo-title{color:#9ca3af;text-decoration:line-through}.todo-edit-input{background:#fff;border:2px solid #667eea;border-radius:4px;flex:1 1;font-size:1rem;padding:.5rem}.todo-edit-input:focus{box-shadow:0 0 0 3px #667eea1a;outline:none}.todo-actions{flex-shrink:0;gap:.5rem}.btn-icon,.todo-actions{align-items:center;display:flex}.btn-icon{background:none;border:none;border-radius:4px;cursor:pointer;font-size:1rem;justify-content:center;padding:.5rem;transition:all .2s ease}.btn-icon:hover{background-color:#f3f4f6}.edit-btn:hover{background-color:#dbeafe}.delete-btn:hover{background-color:#fee2e2}.btn-icon:disabled{cursor:not-allowed;opacity:.5}@media (max-width:640px){.todo-item{padding:.75rem}.todo-content{gap:.5rem}.todo-actions{gap:.25rem}.btn-icon{padding:.375rem}}.todo-list{margin-top:1rem}.empty-state{color:#6b7280;padding:3rem 1rem;text-align:center}.empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-state h3{color:#374151;font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.empty-state p{font-size:1rem;margin:0}.todo-filters{margin-bottom:1.5rem}.filters-row{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.search-container{flex:1 1;min-width:200px;position:relative}.search-input{background:#fff;border:2px solid #e5e7eb;border-radius:8px;font-size:.9rem;padding:.75rem 1rem .75rem 2.5rem;transition:all .2s ease;width:100%}.search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.search-icon{color:#9ca3af;font-size:.9rem;left:.75rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.filter-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.filter-btn{background:#fff;border:2px solid #e5e7eb;border-radius:6px;color:#374151;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap}.filter-btn:hover{border-color:#667eea;color:#667eea}.filter-btn.active{background:#667eea;border-color:#667eea;color:#fff}.filter-btn:focus{box-shadow:0 0 0 3px #667eea1a;outline:none}@media (max-width:768px){.filters-row{align-items:stretch;flex-direction:column}.search-container{min-width:auto}.filter-buttons{justify-content:center}}@media (max-width:480px){.filter-buttons{flex-direction:column}.filter-btn{text-align:center}}.loading-container{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:2rem}.loading-message{color:#666;font-size:.9rem;margin:0}.spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#667eea}.spinner-small{border-width:2px;height:20px;width:20px}.spinner-medium{border-width:3px;height:40px;width:40px}.spinner-large{border-width:4px;height:60px;width:60px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.modal-overlay{align-items:center;animation:fadeIn .3s ease-out;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:slideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:400px;padding:0;width:90%}.modal-header{border-bottom:1px solid #e5e7eb;padding:1.5rem 1.5rem .5rem}.modal-header h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0}.modal-body{padding:1rem 1.5rem}.modal-body p{color:#6b7280;line-height:1.5;margin:0}.modal-footer{display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem 1.5rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.app{align-items:flex-start;display:flex;justify-content:center;min-height:100vh;padding:2rem 1rem}.container{animation:slideUp .5s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:800px;overflow:hidden;width:100%}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;text-align:center}.app-header h1{font-size:2.5rem;font-weight:700;margin:0 0 .5rem;text-shadow:0 2px 4px #0000001a}.app-header p{font-size:1.1rem;font-weight:300;margin:0;opacity:.9}.app-main{padding:2rem}.error-message{color:#6b7280;padding:3rem 2rem;text-align:center}.error-message h2{color:#ef4444;font-size:1.5rem;margin:0 0 1rem}.error-message p{font-size:1rem;margin:0 0 1.5rem}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;justify-content:center;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease;white-space:nowrap}.btn:focus{box-shadow:0 0 0 3px #667eea1a;outline:none}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5a67d8;box-shadow:0 4px 6px #667eea33;transform:translateY(-1px)}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626;box-shadow:0 4px 6px #ef444433;transform:translateY(-1px)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.app{padding:1rem .5rem}.container{border-radius:12px}.app-header{padding:1.5rem 1rem}.app-header h1{font-size:2rem}.app-header p{font-size:1rem}.app-main{padding:1.5rem 1rem}}@media (max-width:480px){.app-header h1{font-size:1.75rem}.app-main{padding:1rem}}.auth-section{align-items:center;display:flex;flex-direction:column;padding:2rem}.auth-header{margin-bottom:1.25rem;text-align:center}.auth-header h2{color:#111827;font-size:1.75rem;font-weight:700;margin:0 0 .5rem}.auth-header p{color:#6b7280;margin:0}.auth-card{background:#fff;border:1px solid #eef2f7;border-radius:16px;box-shadow:0 10px 30px #0000000f;max-width:520px;padding:1.25rem;width:100%}.auth-tabs{background:#f3f4f6;border-radius:12px;display:grid;grid-template-columns:1fr 1fr;margin-bottom:1rem;padding:4px}.auth-tab{background:#0000;border:none;border-radius:10px;color:#6b7280;cursor:pointer;font-weight:600;padding:.6rem .75rem}.auth-tab.active{background:#fff;box-shadow:0 1px 2px #0000000f;color:#111827}.auth-form{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr}.input-group{display:flex;flex-direction:column}.input-group label{color:#374151;font-size:.9rem;margin-bottom:6px}.input{background:#fff;border:1px solid #e5e7eb;border-radius:10px;outline:none;padding:.75rem .9rem}.input:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea26}.password-field{position:relative}.toggle-visibility{background:#0000;border:none;color:#6b7280;cursor:pointer;padding:4px 8px;position:absolute;right:8px;top:50%;transform:translateY(-50%)}.password-meter{background:#eef2f7;border-radius:999px;height:6px;margin-top:6px;overflow:hidden}.password-meter>span{background:linear-gradient(90deg,#f87171,#fbbf24,#34d399,#10b981);display:block;height:100%;transition:width .25s ease;width:0}.auth-actions{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr;margin-top:6px}.helper{color:#6b7280;font-size:.85rem;margin-top:.5rem;text-align:center}.error-text{color:#ef4444;font-size:.85rem}@media (max-width:480px){.auth-card{padding:1rem}.auth-actions{grid-template-columns:1fr}}
/*# sourceMappingURL=main.e145c833.css.map*/