*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f0f4f8;--surface:#fff;--surface-hover:#f8fafc;--border:#e2e8f0;--border-focus:#6366f1;--text-primary:#1e293b;--text-secondary:#64748b;--text-muted:#94a3b8;--accent:#6366f1;--accent-hover:#4f46e5;--accent-light:#eef2ff;--danger:#ef4444;--danger-hover:#dc2626;--danger-light:#fef2f2;--success:#22c55e;--success-light:#f0fdf4;--warning:#f59e0b;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--shadow-sm:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 6px -1px rgba(0,0,0,.08),0 2px 4px -1px rgba(0,0,0,.04);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.08),0 4px 6px -2px rgba(0,0,0,.04);--transition:0.15s ease}body{background-color:var(--bg);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;min-height:100vh}.container{max-width:780px;margin:0 auto;padding:2rem 1rem}.header{text-align:center;margin-bottom:2.5rem}.header h1{font-size:2.25rem;font-weight:800;color:var(--text-primary);letter-spacing:-.5px}.header h1 span{color:var(--accent)}.header p{color:var(--text-secondary);margin-top:.5rem;font-size:1rem}.card{overflow:hidden}.card,.form-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border)}.form-card{padding:1.75rem;margin-bottom:1.5rem}.form-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:1.25rem;display:flex;align-items:center;gap:.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.05em}.form-group input,.form-group textarea{width:100%;padding:.65rem .9rem;border:1.5px solid var(--border);border-radius:var(--radius-md);font-size:.95rem;color:var(--text-primary);background:var(--bg);transition:border-color var(--transition),box-shadow var(--transition);outline:none;font-family:inherit;resize:vertical}.form-group input:focus,.form-group textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px rgba(99,102,241,.1);background:var(--surface)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-row{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.2rem;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;border:1.5px solid transparent;transition:all var(--transition);font-family:inherit;line-height:1;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-secondary{background:transparent;color:var(--text-secondary);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg);color:var(--text-primary)}.btn-danger{background:transparent;color:var(--danger);border-color:var(--danger)}.btn-danger:hover:not(:disabled){background:var(--danger-light);transform:translateY(-1px)}.btn-icon{padding:.45rem;border-radius:var(--radius-sm);background:transparent;border:1.5px solid transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all var(--transition);font-size:1rem;line-height:1}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.btn-icon-edit{color:var(--accent)}.btn-icon-edit:hover:not(:disabled){background:var(--accent-light);border-color:var(--accent)}.btn-icon-delete{color:var(--danger)}.btn-icon-delete:hover:not(:disabled){background:var(--danger-light);border-color:var(--danger)}.btn-icon-save{color:var(--success)}.btn-icon-save:hover:not(:disabled){background:var(--success-light);border-color:var(--success)}.btn-icon-cancel{color:var(--text-muted)}.btn-icon-cancel:hover:not(:disabled){background:var(--bg);border-color:var(--border);color:var(--text-secondary)}.list-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);background:var(--surface)}.list-title{font-size:1rem;font-weight:700;color:var(--text-primary)}.list-count{font-size:.8rem;font-weight:600;color:var(--text-secondary);background:var(--bg);padding:.25rem .6rem;border-radius:999px;border:1px solid var(--border)}.todo-list{list-style:none}.todo-list>li+li{border-top:1px solid var(--border)}.empty-state{text-align:center;padding:3.5rem 2rem;color:var(--text-muted)}.empty-state .empty-icon{font-size:3rem;margin-bottom:1rem;display:block}.empty-state p{font-size:1rem;color:var(--text-secondary);font-weight:500}.empty-state span{font-size:.875rem;color:var(--text-muted);display:block;margin-top:.25rem}.todo-item{display:flex;align-items:flex-start;gap:.85rem;padding:1.1rem 1.5rem;background:var(--surface);transition:background var(--transition)}.todo-item:hover{background:var(--surface-hover)}.todo-item.completed{background:#fafafa}.todo-checkbox-wrapper{padding-top:2px;flex-shrink:0}.todo-checkbox{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:1.2rem;height:1.2rem;border:2px solid var(--border);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);position:relative;background:#fff}.todo-checkbox:checked,.todo-checkbox:hover{border-color:var(--accent)}.todo-checkbox:checked{background:var(--accent)}.todo-checkbox:checked:after{content:"";position:absolute;width:6px;height:4px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg) translateY(-1px)}.todo-checkbox:disabled{opacity:.5;cursor:not-allowed}.todo-content{flex:1 1;min-width:0}.todo-title{font-size:.975rem;font-weight:600;color:var(--text-primary);word-break:break-word;transition:color var(--transition)}.todo-item.completed .todo-title{text-decoration:line-through;color:var(--text-muted)}.todo-description{font-size:.875rem;color:var(--text-secondary);margin-top:.2rem;word-break:break-word;line-height:1.5}.todo-item.completed .todo-description{color:var(--text-muted);text-decoration:line-through}.todo-meta{margin-top:.35rem;display:flex;align-items:center;gap:.5rem}.todo-date{font-size:.75rem;color:var(--text-muted)}.todo-badge{font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}.todo-badge-done{background:var(--success-light);color:var(--success)}.todo-badge-pending{background:var(--accent-light);color:var(--accent)}.todo-actions{display:flex;align-items:center;gap:.25rem;flex-shrink:0;padding-top:1px}.edit-form{flex:1 1;min-width:0}.edit-form .form-group{margin-bottom:.6rem}.edit-form .form-group input,.edit-form .form-group textarea{padding:.5rem .75rem;font-size:.9rem;background:var(--surface)}.edit-actions{display:flex;gap:.4rem;margin-top:.6rem}.loading-wrapper{text-align:center;padding:3rem 2rem}.spinner{display:inline-block;width:2rem;height:2rem;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin-bottom:.75rem}@keyframes spin{to{transform:rotate(1turn)}}.loading-text{color:var(--text-secondary);font-size:.95rem}.error-message{background:var(--danger-light);border:1px solid #fecaca;color:var(--danger);border-radius:var(--radius-md);display:flex;align-items:center;gap:.5rem}.error-message,.success-message{padding:.85rem 1rem;font-size:.9rem;font-weight:500;margin-bottom:1rem}.success-message{background:var(--success-light);border:1px solid #bbf7d0;color:#16a34a;border-radius:var(--radius-md)}.stats-bar{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.stat-item{flex:1 1;min-width:120px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem 1.25rem;box-shadow:var(--shadow-sm)}.stat-value{font-size:1.75rem;font-weight:800;color:var(--text-primary);line-height:1}.stat-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:.25rem}.stat-item.stat-accent .stat-value{color:var(--accent)}.stat-item.stat-success .stat-value{color:var(--success)}.stat-item.stat-warning .stat-value{color:var(--warning)}.filters{display:flex;gap:.5rem;padding:.75rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg);flex-wrap:wrap}.filter-btn{padding:.35rem .85rem;border-radius:999px;font-size:.8rem;font-weight:600;cursor:pointer;border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);transition:all var(--transition);font-family:inherit}.filter-btn:hover{border-color:var(--accent);color:var(--accent)}.filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}@media (max-width:600px){.container{padding:1rem .75rem}.header h1{font-size:1.75rem}.todo-item{padding:.9rem 1rem}.list-header{padding:1rem}.form-card{padding:1.25rem}.stats-bar{gap:.5rem}.stat-item{min-width:80px;padding:.75rem 1rem}.stat-value{font-size:1.4rem}.filters{padding:.6rem 1rem}}