*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f172a;background-image:radial-gradient(at 0% 0%,rgba(59,130,246,.1) 0px,transparent 50%),radial-gradient(at 100% 100%,rgba(139,92,246,.1) 0px,transparent 50%);min-height:100vh}.app{max-width:1400px;margin:0 auto;padding:3rem 1.5rem;min-height:100vh}.app-header{text-align:center;margin-bottom:2.5rem;color:#f8fafc;animation:fadeIn .6s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.app-header h1{font-size:2.5rem;margin-bottom:.75rem;font-weight:700;letter-spacing:-.02em;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-header p{font-size:1rem;color:#94a3b8;font-weight:400}.app-main{background:#1e293b66;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(148,163,184,.1);border-radius:20px;box-shadow:0 0 0 1px #94a3b80d,0 20px 25px -5px #0000004d,0 10px 10px -5px #0003;overflow:hidden;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1440px){.app{max-width:1200px}}@media(max-width:1024px){.app{max-width:960px}}@media(max-width:640px){.app{padding:1rem;max-width:100%}.app-header h1{font-size:2.2rem}}.todo-form{padding:2rem;border-bottom:1px solid rgba(148,163,184,.1);background:#0f172a4d}.input-row{display:flex;gap:.75rem;margin-bottom:1rem}.todo-input{flex:1;padding:.875rem 1.125rem;background:#1e293b80;border:1px solid rgba(148,163,184,.2);border-radius:12px;font-size:.95rem;color:#f8fafc;transition:all .2s;font-family:inherit}.todo-input::placeholder{color:#64748b}.todo-input:focus{outline:none;border-color:#3b82f6;background:#1e293bb3;box-shadow:0 0 0 3px #3b82f61a}.add-btn{padding:.875rem 1.75rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #3b82f64d}.add-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #3b82f666;background:linear-gradient(135deg,#2563eb,#1d4ed8)}.add-btn:active{transform:translateY(0)}.input-options{display:flex;gap:.625rem;flex-wrap:wrap}.priority-select,.category-select,.date-input{padding:.625rem .875rem;background:#1e293b80;border:1px solid rgba(148,163,184,.2);border-radius:10px;font-size:.85rem;color:#cbd5e1;cursor:pointer;transition:all .2s;font-family:inherit}.priority-select:hover,.category-select:hover,.date-input:hover{border-color:#3b82f6;background:#1e293bb3}.priority-select:focus,.category-select:focus,.date-input:focus{outline:none;border-color:#3b82f6;background:#1e293bb3;box-shadow:0 0 0 3px #3b82f61a}@media(max-width:640px){.input-options{flex-direction:column}.priority-select,.category-select,.date-input{width:100%}}.search-bar{margin-bottom:1rem}.search-input{width:100%;padding:.75rem 1rem;background:#1e293b80;border:1px solid rgba(148,163,184,.2);border-radius:12px;font-size:.9rem;color:#f8fafc;transition:all .2s;font-family:inherit}.search-input::placeholder{color:#64748b}.search-input:focus{outline:none;border-color:#3b82f6;background:#1e293bb3;box-shadow:0 0 0 3px #3b82f61a}.filter-buttons{display:flex;gap:.5rem;margin-bottom:1.25rem;justify-content:center;flex-wrap:wrap}.filter-btn{padding:.625rem 1.125rem;background:#1e293b80;border:1px solid rgba(148,163,184,.2);border-radius:10px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s;color:#cbd5e1}.filter-btn:hover{background:#1e293bb3;border-color:#3b82f64d;color:#e2e8f0}.filter-btn.active{background:#3b82f633;color:#60a5fa;border-color:#3b82f666;box-shadow:0 0 0 1px #3b82f633}@media(max-width:640px){.filter-buttons{gap:.375rem}.filter-btn{padding:.5rem .875rem;font-size:.8rem}}.todo-item{display:flex;align-items:flex-start;gap:.875rem;padding:1.125rem 1rem;background:#1e293b4d;border:1px solid rgba(148,163,184,.1);border-radius:12px;transition:all .2s;animation:slideIn .3s ease-out;position:relative;min-height:100px}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.todo-item:hover{background-color:#1e293b80;border-color:#94a3b833;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.todo-item.priority-high{border-left:3px solid #ef4444}.todo-item.priority-medium{border-left:3px solid #f59e0b}.todo-item.priority-low{border-left:3px solid #22c55e}.todo-checkbox{width:18px;height:18px;cursor:pointer;margin-top:.125rem;accent-color:#3b82f6;flex-shrink:0}.todo-content{flex:1;min-width:0}.todo-text{display:block;font-size:.95rem;line-height:1.5;color:#e2e8f0;margin-bottom:.5rem;word-wrap:break-word;cursor:pointer;font-weight:400}.todo-text:hover{color:#3b82f6}.edit-input{width:100%;padding:.5rem .75rem;border:1px solid #3b82f6;border-radius:8px;font-size:.95rem;background:#1e293bb3;color:#f8fafc;font-family:inherit}.edit-input:focus{outline:none;background:#1e293be6;box-shadow:0 0 0 3px #3b82f633}.todo-meta{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.todo-category{display:inline-block;padding:.25rem .625rem;background:#3b82f626;color:#60a5fa;border-radius:6px;font-size:.7rem;font-weight:500;border:1px solid rgba(59,130,246,.2)}.todo-date{display:inline-block;padding:.25rem .625rem;background:#8b5cf626;color:#a78bfa;border-radius:6px;font-size:.7rem;font-weight:500;border:1px solid rgba(139,92,246,.2)}.todo-date.due-today{background:#f59e0b26;color:#fbbf24;border-color:#f59e0b33}.todo-date.overdue{background:#ef444426;color:#f87171;border-color:#ef444433;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.priority-badge{display:inline-block;padding:.25rem .625rem;border-radius:6px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.priority-badge.priority-high{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.2)}.priority-badge.priority-medium{background:#f59e0b26;color:#fbbf24;border:1px solid rgba(245,158,11,.2)}.priority-badge.priority-low{background:#22c55e26;color:#4ade80;border:1px solid rgba(34,197,94,.2)}.delete-btn{padding:.5rem;background:transparent;color:#64748b;border:none;border-radius:8px;font-size:1.1rem;cursor:pointer;transition:all .2s;flex-shrink:0;line-height:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.delete-btn:hover{background:#ef444426;color:#ef4444;transform:scale(1.05)}.todo-item.completed .todo-text{text-decoration:line-through;color:#64748b;opacity:.6}.todo-item.completed .todo-category,.todo-item.completed .todo-date,.todo-item.completed .priority-badge{opacity:.5}@media(max-width:640px){.todo-item{padding:1rem .875rem}}.sort-options{display:flex;align-items:center;gap:.625rem;margin-bottom:1rem;padding:.5rem 0}.sort-label{font-size:.875rem;color:#94a3b8;font-weight:500}.sort-select{padding:.5rem .75rem;background:#1e293b80;border:1px solid rgba(148,163,184,.2);border-radius:8px;font-size:.85rem;color:#cbd5e1;cursor:pointer;transition:all .2s;font-family:inherit;min-width:140px}.sort-select:hover{border-color:#3b82f6;background:#1e293bb3}.sort-select:focus{outline:none;border-color:#3b82f6;background:#1e293bb3;box-shadow:0 0 0 3px #3b82f61a}@media(max-width:640px){.sort-options{justify-content:space-between}}.todo-list-container{padding:1.5rem 2rem}.todo-stats{margin-bottom:1rem;color:#94a3b8;font-size:.875rem;display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.stats-text{font-weight:500}.clear-completed-btn{padding:.375rem .875rem;background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.2);border-radius:8px;font-size:.75rem;cursor:pointer;transition:all .2s;font-weight:500}.clear-completed-btn:hover{background:#ef444440;border-color:#ef44444d;transform:translateY(-1px)}.empty-state{text-align:center;padding:3rem 1rem;color:#64748b}.empty-state p{font-size:1rem;line-height:1.6}.todo-list{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1rem}.keyboard-hint{margin-top:1.5rem;padding-top:1rem;border-top:1px solid rgba(148,163,184,.1);text-align:center;color:#64748b}.keyboard-hint small{font-size:.75rem;line-height:1.5}@media(max-width:1200px){.todo-list{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}}@media(max-width:900px){.todo-list{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media(max-width:640px){.todo-list-container{padding:1.5rem}.todo-list{grid-template-columns:1fr}.keyboard-hint{display:none}}
