*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--primary:#6366f1;--primary-hover:#4f46e5;--danger:#ef4444;--danger-hover:#dc2626;--success:#22c55e;--bg:#f8fafc;--card-bg:#fff;--border:#e2e8f0;--text:#1e293b;--text-muted:#64748b;--radius:10px;--shadow:0 2px 8px rgba(0,0,0,.08);--shadow-lg:0 4px 24px rgba(0,0,0,.12)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}.container{max-width:720px;margin:0 auto;padding:2rem 1rem}.header{text-align:center;margin-bottom:2.5rem}.header h1{font-size:2.5rem;font-weight:700;color:var(--primary);letter-spacing:-.5px}.header p{color:var(--text-muted);margin-top:.5rem;font-size:1rem}.todo-form{background:var(--card-bg);border-radius:var(--radius);padding:1.5rem;margin-bottom:2rem;box-shadow:var(--shadow);border:1px solid var(--border)}.todo-form h2{font-size:1.125rem;font-weight:600;color:var(--text)}.form-group,.todo-form h2{margin-bottom:1rem}.form-group label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.375rem;color:var(--text-muted)}.form-group input,.form-group textarea{width:100%;padding:.625rem .875rem;border:1px solid var(--border);border-radius:6px;font-size:.9375rem;color:var(--text);background:var(--bg);transition:border-color .15s,box-shadow .15s;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(99,102,241,.15)}.form-group textarea{resize:vertical;min-height:80px}.btn{display:inline-flex;align-items:center;gap:.375rem;padding:.625rem 1.25rem;border-radius:6px;font-size:.9375rem;font-weight:500;border:none;cursor:pointer;transition:background-color .15s,transform .1s;font-family:inherit}.btn:active{transform:scale(.98)}.btn-primary{background-color:var(--primary);color:#fff;width:100%;justify-content:center}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-danger{background-color:transparent;color:var(--danger);padding:.375rem .75rem;font-size:.8125rem;border:1px solid var(--danger)}.btn-danger:hover{background-color:var(--danger);color:#fff}.btn-secondary{background-color:transparent;color:var(--text-muted);padding:.375rem .75rem;font-size:.8125rem;border:1px solid var(--border)}.btn-secondary:hover{background-color:var(--border)}.btn-success{background-color:var(--success);color:#fff;padding:.375rem .75rem;font-size:.8125rem}.btn-success:hover{background-color:#16a34a}.todo-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.todo-list-header h2{font-size:1.125rem;font-weight:600}.todo-count{background:var(--primary);color:#fff;font-size:.75rem;font-weight:600;padding:.2rem .6rem;border-radius:999px}.todo-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted);background:var(--card-bg);border-radius:var(--radius);border:2px dashed var(--border)}.todo-empty .empty-icon{font-size:3rem;margin-bottom:.75rem}.todo-empty p{font-size:1rem}.todos-container{display:flex;flex-direction:column;gap:.75rem}.todo-item{background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);transition:box-shadow .15s,border-color .15s;overflow:hidden}.todo-item:hover{box-shadow:var(--shadow-lg);border-color:#c7d2fe}.todo-item.completed{opacity:.7}.todo-item-content{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.25rem}.todo-checkbox{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);background:transparent;cursor:pointer;flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;transition:border-color .15s,background-color .15s}.todo-checkbox:hover{border-color:var(--primary)}.todo-checkbox.checked{background-color:var(--success);border-color:var(--success);color:#fff}.todo-body{flex:1 1;min-width:0}.todo-title{font-size:1rem;font-weight:500;color:var(--text);word-break:break-word}.todo-item.completed .todo-title{text-decoration:line-through;color:var(--text-muted)}.todo-description{font-size:.875rem;color:var(--text-muted);margin-top:.25rem;word-break:break-word}.todo-meta{font-size:.75rem;color:var(--text-muted);margin-top:.375rem}.todo-actions{display:flex;gap:.5rem;flex-shrink:0;align-items:center}.todo-edit-form{padding:1rem 1.25rem;border-top:1px solid var(--border);background:var(--bg)}.todo-edit-form .form-group{margin-bottom:.75rem}.todo-edit-form .form-group:last-of-type{margin-bottom:1rem}.edit-actions{display:flex;gap:.5rem;justify-content:flex-end}.loading{text-align:center;padding:2rem;color:var(--text-muted)}.spinner{display:inline-block;width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:.5rem}@keyframes spin{to{transform:rotate(1turn)}}.error-banner{background:#fef2f2;border:1px solid #fecaca;color:var(--danger);padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem;display:flex;align-items:center;gap:.5rem}.filter-tabs{display:flex;gap:.375rem;margin-bottom:1.25rem}.filter-tab{padding:.375rem .875rem;border-radius:999px;font-size:.875rem;font-weight:500;border:1px solid var(--border);background:var(--card-bg);color:var(--text-muted);cursor:pointer;transition:all .15s}.filter-tab:hover{border-color:var(--primary);color:var(--primary)}.filter-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}@media (max-width:480px){.header h1{font-size:1.875rem}.todo-item-content{flex-wrap:wrap}.todo-actions{width:100%;justify-content:flex-end}}