*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--primary:#6366f1;--primary-hover:#4f46e5;--primary-light:#e0e7ff;--danger:#ef4444;--danger-hover:#dc2626;--success:#22c55e;--success-hover:#16a34a;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--white:#fff;--shadow-sm:0 1px 2px rgba(0,0,0,.05);--shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);--shadow-md:0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.06);--shadow-lg:0 10px 15px rgba(0,0,0,.1),0 4px 6px rgba(0,0,0,.05);--radius:8px;--radius-lg:12px;--transition:0.2s ease}body,html{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;color:var(--gray-800);line-height:1.5}.container{max-width:720px;margin:0 auto;padding:2rem 1rem}.app-header{text-align:center;margin-bottom:2rem}.app-header h1{font-size:2.5rem;font-weight:800;color:var(--white);letter-spacing:-.5px;text-shadow:0 2px 4px rgba(0,0,0,.1)}.app-header p{color:hsla(0,0%,100%,.8);margin-top:.5rem;font-size:1rem}.card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:1.5rem;margin-bottom:1rem}.add-form{display:flex;flex-direction:column;gap:.75rem}.add-form h2{font-size:1.125rem;font-weight:600;color:var(--gray-700);margin-bottom:.25rem}.form-row{display:flex;gap:.75rem;align-items:flex-start}.input{width:100%;padding:.625rem .875rem;border:1.5px solid var(--gray-200);border-radius:var(--radius);font-size:.9375rem;color:var(--gray-800);background:var(--gray-50);transition:border-color var(--transition),box-shadow var(--transition);outline:none}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(99,102,241,.15);background:var(--white)}.input::placeholder{color:var(--gray-400)}textarea.input{resize:vertical;min-height:70px;font-family:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.625rem 1.25rem;border:none;border-radius:var(--radius);font-size:.9375rem;font-weight:600;cursor:pointer;transition:background var(--transition),transform var(--transition),box-shadow var(--transition);white-space:nowrap;text-decoration:none}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:var(--white);box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--primary-hover);box-shadow:var(--shadow)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-danger{background:var(--danger);color:var(--white)}.btn-danger:hover{background:var(--danger-hover)}.btn-ghost{background:transparent;color:var(--gray-500);border:1.5px solid var(--gray-200)}.btn-ghost:hover{background:var(--gray-100);color:var(--gray-700)}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.btn-icon{padding:.4rem;border-radius:var(--radius);background:transparent;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--gray-400);transition:background var(--transition),color var(--transition)}.btn-icon:hover{background:var(--gray-100);color:var(--gray-700)}.btn-icon.danger:hover{background:#fee2e2;color:var(--danger)}.list-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.filter-group{display:flex;gap:.375rem;background:var(--gray-100);border-radius:var(--radius);padding:.25rem}.filter-btn{padding:.375rem .875rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;background:transparent;color:var(--gray-500);transition:all var(--transition)}.filter-btn.active{background:var(--white);color:var(--primary);box-shadow:var(--shadow-sm);font-weight:600}.filter-btn:hover:not(.active){color:var(--gray-700)}.active-count{font-size:.875rem;color:var(--gray-500);font-weight:500}.active-count span{font-weight:700;color:var(--primary)}.todo-list{display:flex;flex-direction:column;gap:.625rem}.empty-state{text-align:center;padding:3rem 1rem;color:var(--gray-400)}.empty-state .empty-icon{font-size:3rem;margin-bottom:.75rem}.empty-state p{font-size:1rem;font-weight:500}.empty-state small{font-size:.875rem;color:var(--gray-300)}.todo-item{background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--radius);padding:1rem 1.125rem;display:flex;align-items:flex-start;gap:.875rem;transition:border-color var(--transition),box-shadow var(--transition);box-shadow:var(--shadow-sm)}.todo-item:hover{border-color:var(--gray-300);box-shadow:var(--shadow)}.todo-item.completed-item{background:var(--gray-50);border-color:var(--gray-100)}.checkbox-wrap{flex-shrink:0;margin-top:2px}.checkbox{width:20px;height:20px;border-radius:50%;border:2px solid var(--gray-300);background:var(--white);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);outline:none;padding:0}.checkbox:hover{border-color:var(--primary)}.checkbox.checked{background:var(--success);border-color:var(--success)}.checkbox.checked:hover{background:var(--success-hover);border-color:var(--success-hover)}.checkmark{color:#fff;font-size:12px;font-weight:700;line-height:1}.todo-content{flex:1 1;min-width:0}.todo-title{font-size:.9375rem;font-weight:600;color:var(--gray-800);margin-bottom:.25rem;word-break:break-word}.todo-title.completed-text{text-decoration:line-through;color:var(--gray-400)}.todo-desc{font-size:.875rem;color:var(--gray-500);margin-bottom:.375rem;word-break:break-word}.todo-date{font-size:.75rem;color:var(--gray-400)}.todo-actions{display:flex;gap:.25rem;flex-shrink:0;margin-top:-2px}.edit-form{display:flex;flex-direction:column;gap:.5rem;flex:1 1}.edit-actions{display:flex;gap:.5rem;margin-top:.25rem}.loading-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem}.spinner{width:36px;height:36px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.loading-text{color:var(--gray-500);font-size:.9375rem}.error-banner{background:#fee2e2;border:1px solid #fecaca;border-radius:var(--radius);padding:.875rem 1rem;color:var(--danger);font-size:.9rem;display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.badge{display:inline-block;padding:.125rem .5rem;border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.badge-completed{background:#dcfce7;color:#15803d}.badge-active{background:var(--primary-light);color:var(--primary-hover)}@media (max-width:540px){.app-header h1{font-size:2rem}.list-header{align-items:flex-start}.form-row,.list-header{flex-direction:column}.form-row .btn{width:100%}}