.todo-form-wrapper{background:linear-gradient(135deg,#fff,#f8f9fa);border:1px solid #4facfe1a;border-radius:20px;box-shadow:0 10px 30px #0000001a,0 1px 8px #0000000d;margin-bottom:2rem;overflow:hidden;padding:2rem;position:relative}.todo-form-wrapper:before{animation:gradientShift 3s ease-in-out infinite;background:linear-gradient(90deg,#4facfe,#00f2fe 50%,#4facfe);background-size:200% 100%;content:"";height:4px;left:0;position:absolute;right:0;top:0}@keyframes gradientShift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.todo-form{display:flex;flex-direction:column;gap:1.5rem;position:relative}.todo-form.success-animation{animation:successPulse .6s ease-out}@keyframes successPulse{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.form-header{margin-bottom:1rem;text-align:center}.form-title{align-items:center;color:#333;display:flex;font-size:1.5rem;font-weight:700;gap:.75rem;justify-content:center;margin:0 0 .5rem}.form-icon{animation:sparkle 2s ease-in-out infinite;font-size:1.75rem}@keyframes sparkle{0%,to{transform:scale(1) rotate(0deg)}50%{transform:scale(1.1) rotate(5deg)}}.form-description{color:#666;font-size:.95rem;font-style:italic;margin:0}.input-group{display:flex;flex-direction:column;gap:.75rem}.input-container{align-items:center;display:flex;position:relative}.todo-input{background:#fff;border:2px solid #e1e5e9;border-radius:16px;box-sizing:border-box;color:#333;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:1.1rem;font-weight:500;line-height:1.5;outline:none;padding:1.25rem 1.5rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%;z-index:2}.todo-input::placeholder{color:#999;font-style:italic;transition:all .3s ease}.todo-input:focus::placeholder{opacity:.7;transform:translateY(-2px)}.todo-input:focus{background:#fff;border-color:#4facfe;box-shadow:0 0 0 4px #4facfe1a,0 8px 25px #4facfe26;transform:translateY(-2px)}.todo-input.has-content{background:linear-gradient(135deg,#fff,#f8fbff);border-color:#4facfe}.todo-input.error{animation:inputShake .4s ease-in-out;background:#fff8f8;border-color:#ff6b6b}.todo-input.error:focus{border-color:#ff6b6b;box-shadow:0 0 0 4px #ff6b6b1a,0 8px 25px #ff6b6b26}.todo-input:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.6;transform:none}@keyframes inputShake{0%,to{transform:translateX(0)}25%{transform:translateX(-8px)}75%{transform:translateX(8px)}}.input-border{background:linear-gradient(135deg,#4facfe,#00f2fe) border-box;border:2px solid #0000;border-radius:16px;bottom:0;left:0;-webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;pointer-events:none;position:absolute;right:0;top:0;transition:opacity .3s ease}.todo-input:focus+.input-border{opacity:1}.input-focus-effect{background:linear-gradient(90deg,#4facfe,#00f2fe);border-radius:1px;height:2px;left:1.5rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);transition:width .3s ease;width:0}.todo-input:focus~.input-focus-effect{width:calc(100% - 3rem)}.input-meta{align-items:center;display:flex;justify-content:space-between}.input-actions{gap:.75rem;margin-left:auto}.character-count{font-weight:600;transition:all .3s ease}.character-count.danger{animation:pulse 1s infinite}.clear-btn{align-items:center;background:#ff6b6b;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:.75rem;height:24px;justify-content:center;transition:all .3s ease;width:24px}.clear-btn:hover{background:#ff5252;transform:scale(1.1)}.clear-btn:active{transform:scale(.95)}.clear-icon{font-weight:700}.error-message{background:linear-gradient(135deg,#fff5f5,#ffe6e6);border-radius:10px}.error-icon{animation:errorPulse 2s infinite}@keyframes errorPulse{0%,to{opacity:1}50%{opacity:.6}}.input-hint{background:#4facfe0d;border:1px solid #4facfe1a;border-radius:8px;color:#888;font-size:.75rem;padding:.5rem;text-align:center}.input-hint kbd{background:linear-gradient(135deg,#f0f0f0,#e0e0e0);border:1px solid #ccc;border-radius:4px;box-shadow:0 2px 4px #0000001a;color:#333;display:inline-block;font-family:Courier New,monospace;font-size:.7rem;font-weight:700;margin:0 .2rem;min-width:1.5rem;padding:.2rem .4rem;text-align:center}.todo-submit-btn{align-items:center;background:linear-gradient(135deg,#4facfe,#00f2fe);border:none;border-radius:16px;box-shadow:0 8px 25px #4facfe4d,0 4px 10px #0000001a;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:1.1rem;font-weight:700;gap:.75rem;justify-content:center;letter-spacing:1px;min-height:60px;overflow:hidden;padding:1.25rem 2rem;position:relative;text-transform:uppercase;transition:all .3s cubic-bezier(.4,0,.2,1)}.todo-submit-btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s;width:100%}.todo-submit-btn:hover:not(:disabled){box-shadow:0 12px 35px #4facfe66,0 8px 15px #00000026;transform:translateY(-3px)}.todo-submit-btn:hover:not(:disabled):before{left:100%}.todo-submit-btn:active:not(:disabled){transform:translateY(-1px);transition:transform .1s}.todo-submit-btn.disabled,.todo-submit-btn:disabled{background:linear-gradient(135deg,#ccc,#999);box-shadow:0 4px 10px #0000001a;cursor:not-allowed;transform:none}.todo-submit-btn.loading{background:linear-gradient(135deg,#6bb6ff,#33d4ff);cursor:wait}.btn-icon{font-size:1.5rem}.todo-submit-btn:hover:not(:disabled) .btn-icon{transform:scale(1.2) rotate(90deg)}.btn-ripple{background:#ffffff4d;border-radius:50%;height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .3s,height .3s;width:0}.todo-submit-btn:active:not(:disabled) .btn-ripple{height:300px;transition:width .1s,height .1s;width:300px}.loading-spinner{border:3px solid #ffffff4d;height:20px;width:20px}.form-stats{border-top:1px solid #e0e0e0;margin-top:2rem;padding-top:1.5rem}.quick-tips{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-left:4px solid #4facfe;border-radius:12px;padding:1.5rem}.quick-tips h4{align-items:center;color:#333;display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin:0 0 1rem}.quick-tips h4:before{content:"💡";font-size:1.2rem}.quick-tips ul{list-style:none;margin:0;padding-left:1.5rem}.quick-tips li{color:#666;font-size:.875rem;line-height:1.4;margin-bottom:.5rem;position:relative}.quick-tips li:before{color:#4facfe;content:"→";font-weight:700;left:-1.5rem;position:absolute}.quick-tips li:last-child{margin-bottom:0}@media (max-width:768px){.todo-form-wrapper{border-radius:16px;padding:1.5rem}.form-title{font-size:1.25rem;gap:.5rem}.form-icon{font-size:1.5rem}.form-description{font-size:.875rem}.todo-input{padding:1rem 1.25rem}.todo-input,.todo-submit-btn{border-radius:12px;font-size:1rem}.todo-submit-btn{min-height:50px;padding:1rem 1.5rem}.btn-icon{font-size:1.25rem}.character-count,.input-hint{font-size:.7rem}.quick-tips{padding:1rem}.quick-tips h4{font-size:.9rem}.quick-tips li{font-size:.8rem}}@media (max-width:480px){.todo-form-wrapper{border-radius:12px;padding:1rem}.form-title{flex-direction:column;font-size:1.1rem;gap:.25rem}.todo-input{padding:.875rem 1rem}.todo-input,.todo-submit-btn{border-radius:10px;font-size:.9rem}.todo-submit-btn{gap:.5rem;min-height:45px;padding:.875rem 1.25rem}.input-actions{gap:.5rem}.clear-btn{font-size:.7rem;height:20px;width:20px}.error-message{font-size:.8rem;padding:.5rem .75rem}.quick-tips{padding:.75rem}.quick-tips ul{padding-left:1rem}}.todo-item{align-items:center;background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #e1e5e9;border-radius:16px;box-shadow:0 4px 12px #0000000d,0 2px 4px #00000005;display:flex;justify-content:space-between;margin-bottom:1rem;min-height:70px;overflow:hidden;padding:1.25rem 1.5rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.todo-item:before{background:linear-gradient(135deg,#4facfe,#00f2fe);content:"";height:100%;left:0;position:absolute;top:0;transform:scaleY(0);transform-origin:bottom;transition:transform .3s ease;width:4px}.todo-item:hover{border-color:#4facfe;box-shadow:0 8px 25px #0000001a,0 4px 8px #0000000d;transform:translateY(-2px)}.todo-item:hover:before{transform:scaleY(1)}.todo-item.completed{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-color:#28a745;opacity:.8}.todo-item.completed:before{background:linear-gradient(135deg,#28a745,#20c997);transform:scaleY(1)}.todo-item.deleting{animation:deleteSlideOut .4s ease-in-out forwards;pointer-events:none}@keyframes deleteSlideOut{0%{margin-bottom:1rem;max-height:100px;opacity:1;transform:translateX(0) scale(1)}50%{opacity:.5;transform:translateX(20px) scale(.95)}to{margin-bottom:0;max-height:0;opacity:0;padding:0;transform:translateX(100px) scale(.8)}}.todo-content{align-items:center;display:flex;flex:1 1;gap:1rem;min-width:0}.todo-checkbox-container{flex-shrink:0;position:relative}.todo-checkbox{align-items:center;background:#fff;border:2px solid #ddd;border-radius:8px;cursor:pointer;display:flex;height:24px;justify-content:center;overflow:hidden;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);width:24px}.todo-checkbox:hover{background:#f8fbff;border-color:#4facfe;transform:scale(1.05)}.todo-checkbox.checked{background:linear-gradient(135deg,#28a745,#20c997);border-color:#28a745;color:#fff}.todo-checkbox.toggling{animation:checkboxPulse .6s ease-in-out}@keyframes checkboxPulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.checkbox-inner{align-items:center;display:flex;height:100%;justify-content:center;position:relative;width:100%;z-index:2}.check-icon{animation:checkSlideIn .3s ease-out;font-size:.75rem}@keyframes checkSlideIn{0%{opacity:0;transform:scale(0) rotate(45deg)}to{opacity:1;transform:scale(1) rotate(0deg)}}.checkbox-spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:12px;width:12px}.checkbox-ripple{background:#4facfe4d;border-radius:50%;height:0;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .3s,height .3s;width:0}.todo-checkbox:active .checkbox-ripple{height:40px;width:40px}.todo-text-container{display:flex;flex:1 1;flex-direction:column;gap:.25rem;min-width:0}.todo-text{word-wrap:break-word;color:#333;cursor:pointer;font-size:1rem;font-weight:500;line-height:1.4;margin:0;position:relative;transition:all .3s ease}.todo-text:hover{color:#4facfe}.todo-text.completed-text{animation:strikethrough .3s ease-out;color:#6c757d;text-decoration:line-through;text-decoration-color:#28a745;text-decoration-thickness:2px}@keyframes strikethrough{0%{text-decoration:none}to{text-decoration:line-through}}.todo-metadata{align-items:center;color:#6c757d;display:flex;font-size:.75rem;gap:.375rem;margin-top:.25rem}.metadata-icon{font-size:.7rem;opacity:.7}.todo-date{font-weight:500}.todo-actions{align-items:center;display:flex;flex-shrink:0;gap:.5rem;opacity:0;transform:translateX(10px);transition:all .3s ease}.todo-item:hover .todo-actions{opacity:1;transform:translateX(0)}.todo-action-btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;height:36px;justify-content:center;overflow:hidden;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);width:36px}.todo-action-btn:hover{transform:translateY(-2px)}.todo-action-btn:active{transform:translateY(0)}.edit-btn{background:linear-gradient(135deg,#4facfe,#00f2fe);box-shadow:0 4px 12px #4facfe4d;color:#fff}.edit-btn:hover{box-shadow:0 6px 20px #4facfe66}.delete-btn{background:linear-gradient(135deg,#ff6b6b,#ff5252);box-shadow:0 4px 12px #ff6b6b4d;color:#fff}.delete-btn:hover{box-shadow:0 6px 20px #ff6b6b66}.undo-btn{background:linear-gradient(135deg,#ffc107,#ff9800);box-shadow:0 4px 12px #ffc1074d;color:#fff}.undo-btn:hover{box-shadow:0 6px 20px #ffc10766}.action-icon{font-size:.875rem;transition:transform .3s ease}.todo-action-btn:hover .action-icon{transform:scale(1.1)}.action-icon.deleting{animation:deleteShake .4s ease-in-out}@keyframes deleteShake{0%,to{transform:rotate(0deg)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}.btn-tooltip{background:#000c;border-radius:6px;bottom:100%;color:#fff;font-size:.75rem;font-weight:500;margin-bottom:.5rem;opacity:0;padding:.375rem .75rem;pointer-events:none;transition:all .3s ease;visibility:hidden;white-space:nowrap;z-index:10}.btn-tooltip,.btn-tooltip:after{left:50%;position:absolute;transform:translateX(-50%)}.btn-tooltip:after{border:4px solid #0000;border-top-color:#000c;content:"";top:100%}.todo-action-btn:hover .btn-tooltip{opacity:1;transform:translateX(-50%) translateY(-2px);visibility:visible}.todo-priority-indicator{border-color:#0000 #4facfe #0000 #0000;border-style:solid;border-width:0 20px 20px 0;height:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease;width:0}.todo-item.high-priority .todo-priority-indicator{border-right-color:#ff6b6b;opacity:1}.todo-item.medium-priority .todo-priority-indicator{border-right-color:#ffc107;opacity:1}.todo-item.low-priority .todo-priority-indicator{border-right-color:#28a745;opacity:1}@media (max-width:768px){.todo-item{align-items:stretch;border-radius:12px;flex-direction:column;gap:1rem;min-height:auto;padding:1rem}.todo-content{gap:.75rem}.todo-checkbox{border-radius:6px;height:20px;width:20px}.check-icon{font-size:.7rem}.todo-text{font-size:.9rem}.todo-metadata{font-size:.7rem}.todo-actions{border-top:1px solid #e1e5e9;gap:1rem;justify-content:center;margin-top:.5rem;opacity:1;padding-top:.75rem;transform:translateX(0)}.todo-action-btn{border-radius:12px;height:40px;width:40px}.action-icon{font-size:1rem}.btn-tooltip{display:none}}@media (max-width:480px){.todo-item{border-radius:10px;margin-bottom:.75rem;padding:.875rem}.todo-content{gap:.5rem}.todo-checkbox{border-radius:5px;height:18px;width:18px}.check-icon{font-size:.65rem}.todo-text{font-size:.85rem;line-height:1.3}.todo-metadata{font-size:.65rem;gap:.25rem}.metadata-icon{font-size:.6rem}.todo-actions{gap:.75rem;margin-top:.375rem;padding-top:.5rem}.todo-action-btn{border-radius:10px;height:36px;width:36px}.action-icon{font-size:.9rem}}.todo-action-btn:focus,.todo-checkbox:focus,.todo-text:focus{outline:3px solid #4facfe;outline-offset:2px}.todo-text:focus{outline-style:dashed}.todo-item.loading{opacity:.6;pointer-events:none}.todo-item.loading:after{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#0000,#fff6,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.todo-item.dragging{box-shadow:0 10px 30px #0000004d;opacity:.5;transform:rotate(5deg);z-index:1000}.todo-item.drag-over{background:linear-gradient(135deg,#f8fbff,#e3f2fd);border-color:#4facfe}.todo-text-container::-webkit-scrollbar{width:4px}.todo-text-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.todo-text-container::-webkit-scrollbar-thumb{background:#4facfe;border-radius:2px}.todo-text-container::-webkit-scrollbar-thumb:hover{background:#357abd}.todo-item.new-item{animation:slideInFromRight .5s ease-out}@keyframes slideInFromRight{0%{opacity:0;transform:translateX(100px)}to{opacity:1;transform:translateX(0)}}.todo-item:hover .todo-text{color:#4facfe}.todo-item.completed:hover .todo-text.completed-text{color:#28a745}.todo-item:focus-within{border-color:#4facfe;box-shadow:0 0 0 3px #4facfe1a}.edit-todo-wrapper{animation:editSlideIn .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #4facfe;border-radius:16px;box-shadow:0 10px 30px #4facfe26,0 4px 8px #0000000d;margin:.5rem 0;padding:1.5rem;position:relative}.edit-todo-wrapper:before{background:linear-gradient(90deg,#4facfe,#00f2fe);border-radius:16px 16px 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}@keyframes editSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.edit-todo-form{display:flex;flex-direction:column;gap:1.25rem}.edit-input-container,.edit-input-group{display:flex;flex-direction:column;gap:.5rem}.edit-input-container{position:relative}.edit-todo-input{background:#fff;border:2px solid #e1e5e9;border-radius:12px;box-sizing:border-box;color:#333;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:1rem;font-weight:500;line-height:1.5;outline:none;padding:1rem 1.25rem;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.edit-todo-input:focus{border-color:#4facfe;box-shadow:0 0 0 4px #4facfe1a,0 4px 12px #4facfe26;transform:translateY(-2px)}.edit-todo-input.error{animation:shake .4s ease-in-out;background:#fff8f8;border-color:#ff6b6b}.edit-todo-input.error:focus{border-color:#ff6b6b;box-shadow:0 0 0 4px #ff6b6b1a,0 4px 12px #ff6b6b26}.edit-todo-input:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.6;transform:none}.edit-todo-input::placeholder{color:#999;font-style:italic}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.input-actions{align-items:center;display:flex;justify-content:flex-end;margin-top:.25rem}.character-count{background:#f0f0f0;border-radius:6px;color:#666;font-size:.75rem;font-weight:500;padding:.25rem .5rem;transition:color .3s ease}.character-count.warning{background:#fff4e6;color:#ff9500}.character-count.danger{background:#ffe6e6;color:#ff6b6b}.error-message{align-items:center;animation:errorSlideIn .3s ease-out;background:#fff5f5;border-left:4px solid #ff6b6b;border-radius:8px;color:#ff6b6b;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1rem}@keyframes errorSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-icon{animation:pulse 2s infinite;font-size:1rem}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.edit-form-buttons{align-items:center;display:flex;gap:.75rem;justify-content:flex-end}.edit-cancel-btn,.edit-save-btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;letter-spacing:.5px;min-width:110px;overflow:hidden;padding:.875rem 1.5rem;position:relative;text-transform:uppercase;transition:all .3s cubic-bezier(.4,0,.2,1)}.edit-save-btn{background:linear-gradient(135deg,#4facfe,#00f2fe);box-shadow:0 4px 15px #4facfe4d;color:#fff}.edit-save-btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.edit-save-btn:hover:not(:disabled){box-shadow:0 8px 25px #4facfe66;transform:translateY(-3px)}.edit-save-btn:hover:not(:disabled):before{left:100%}.edit-save-btn:active:not(:disabled){transform:translateY(-1px);transition:transform .1s}.edit-save-btn.disabled,.edit-save-btn:disabled{background:linear-gradient(135deg,#ccc,#999);box-shadow:none;cursor:not-allowed;transform:none}.edit-cancel-btn{background:#fff;border:2px solid #e1e5e9;box-shadow:0 2px 8px #0000001a;color:#666}.edit-cancel-btn:hover:not(:disabled){background:#f8f9fa;border-color:#ff6b6b;box-shadow:0 6px 20px #ff6b6b33;color:#ff6b6b;transform:translateY(-2px)}.edit-cancel-btn:active:not(:disabled){transform:translateY(0);transition:transform .1s}.edit-cancel-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.btn-icon{font-size:1rem;font-weight:700;transition:transform .3s ease}.edit-save-btn:hover:not(:disabled) .btn-icon{transform:scale(1.1)}.edit-cancel-btn:hover:not(:disabled) .btn-icon{transform:rotate(90deg)}.loading-spinner{border:2px solid #ffffff4d;height:16px;width:16px}.edit-form-hint{background:#4facfe0d;border:1px solid #4facfe1a;border-radius:8px;margin-top:1rem;padding:.75rem;text-align:center}.hint-text{color:#666;font-size:.75rem;font-weight:500}.edit-form-hint kbd{background:linear-gradient(135deg,#f0f0f0,#e0e0e0);border:1px solid #ccc;border-radius:4px;box-shadow:0 2px 4px #0000001a;color:#333;font-family:Courier New,monospace;font-size:.7rem;font-weight:700;margin:0 .2rem;padding:.2rem .4rem}@media (max-width:768px){.edit-todo-wrapper{border-radius:12px;margin:.25rem 0;padding:1.25rem}.edit-todo-input{font-size:.9rem;padding:.875rem 1rem}.edit-form-buttons{flex-direction:column;gap:.5rem}.edit-cancel-btn,.edit-save-btn{min-width:auto;padding:1rem;width:100%}.character-count{font-size:.7rem}.edit-form-hint{margin-top:.75rem;padding:.5rem}.hint-text{font-size:.7rem}}@media (max-width:480px){.edit-todo-wrapper{border-radius:10px;padding:1rem}.edit-todo-input{font-size:.875rem;padding:.75rem}.edit-cancel-btn,.edit-save-btn{font-size:.8rem;gap:.375rem;padding:.875rem}.btn-icon{font-size:.875rem}.error-message{font-size:.8rem;padding:.5rem .75rem}}.edit-cancel-btn:focus,.edit-save-btn:focus{outline:3px solid #4facfe;outline-offset:2px}.todo-wrapper{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh;padding:2rem 1rem}.todo-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 20px 40px #0000001a;margin:0 auto;max-width:800px;overflow:hidden}.todo-header{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;padding:3rem 2rem 2rem;position:relative;text-align:center}.todo-header:before{bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}.todo-title{font-size:2.5rem;font-weight:700;margin:0 0 .5rem}.todo-subtitle,.todo-title{position:relative;z-index:1}.todo-subtitle{font-size:1.1rem;margin:0;opacity:.9}.todo-form-section{padding:2rem}.todo-form-section,.todo-stats{border-bottom:1px solid #e0e0e0}.todo-stats{background:#f8f9fa;display:flex;gap:2rem;justify-content:center;padding:1.5rem 2rem}.stats-item{align-items:center;display:flex;flex-direction:column;gap:.25rem}.stats-number{color:#4facfe;font-size:1.5rem;font-weight:700}.stats-label{color:#666;font-size:.875rem;letter-spacing:.5px;text-transform:uppercase}.todo-filters{background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;padding:1.5rem 2rem}.filter-btn{background:#fff;border:2px solid #ddd;border-radius:25px;color:#666;cursor:pointer;font-size:.875rem;font-weight:500;letter-spacing:.5px;padding:.5rem 1rem;text-transform:uppercase;transition:all .3s ease}.filter-btn:hover{border-color:#4facfe;color:#4facfe;transform:translateY(-1px)}.filter-btn.active{background:#4facfe;border-color:#4facfe;box-shadow:0 4px 12px #4facfe4d;color:#fff}.clear-completed-btn{background:#fff;border:2px solid #ff6b6b;border-radius:25px;color:#ff6b6b;cursor:pointer;font-size:.875rem;font-weight:500;letter-spacing:.5px;margin-left:1rem;padding:.5rem 1rem;text-transform:uppercase;transition:all .3s ease}.clear-completed-btn:hover{background:#ff6b6b;box-shadow:0 4px 12px #ff6b6b4d;color:#fff;transform:translateY(-1px)}.todo-list{max-height:500px;overflow-y:auto;padding:1rem 0}.todo-list::-webkit-scrollbar{width:6px}.todo-list::-webkit-scrollbar-track{background:#f1f1f1}.todo-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.todo-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.todo-item-wrapper{border-radius:12px;margin:.5rem 1rem;overflow:hidden;transition:all .3s ease}.todo-item-wrapper:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-2px)}.empty-state{color:#666;padding:4rem 2rem;text-align:center}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state h3{color:#333;font-size:1.5rem;margin:0 0 1rem}.empty-state p{font-size:1rem;margin:0;opacity:.8}@media (max-width:768px){.todo-wrapper{padding:1rem .5rem}.todo-container{border-radius:15px;margin:0}.todo-header{padding:2rem 1rem 1.5rem}.todo-title{font-size:2rem}.todo-subtitle{font-size:1rem}.todo-form-section{padding:1.5rem 1rem}.todo-stats{gap:1rem;padding:1rem}.stats-number{font-size:1.25rem}.todo-filters{gap:.25rem;padding:1rem}.clear-completed-btn,.filter-btn{font-size:.75rem;padding:.4rem .8rem}.clear-completed-btn{margin-left:.5rem;margin-top:.5rem}.todo-list{max-height:400px}.todo-item-wrapper{margin:.5rem}.empty-state{padding:3rem 1rem}.empty-icon{font-size:3rem}}@media (max-width:480px){.todo-stats{flex-direction:row;gap:1.5rem}.todo-filters{align-items:center;flex-direction:column;gap:.5rem}.clear-completed-btn,.filter-btn{margin:0;width:200px}.clear-completed-btn{margin-top:.5rem}.todo-title{font-size:1.75rem}.todo-subtitle{font-size:.9rem}.stats-item{min-width:60px}.stats-number{font-size:1.1rem}.stats-label{font-size:.75rem}.empty-state{padding:2rem 1rem}.empty-icon{font-size:2.5rem}.empty-state h3{font-size:1.25rem}.empty-state p{font-size:.9rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.todo-item-wrapper{animation:fadeIn .3s ease-out}.clear-completed-btn:focus,.filter-btn:focus{outline:2px solid #4facfe;outline-offset:2px}:root{--primary-color:#4facfe;--primary-gradient:linear-gradient(135deg,#4facfe,#00f2fe);--secondary-color:#6c757d;--success-color:#28a745;--warning-color:#ffc107;--danger-color:#ff6b6b;--light-color:#f8f9fa;--dark-color:#343a40;--white:#fff;--black:#000;--bg-primary:#fff;--bg-secondary:#f8f9fa;--bg-tertiary:#e9ecef;--text-primary:#333;--text-secondary:#6c757d;--text-muted:#999;--border-color:#e1e5e9;--shadow-light:#0000001a;--shadow-medium:#00000026;--shadow-heavy:#00000040;--font-family-primary:"Segoe UI",Tahoma,Geneva,Verdana,sans-serif;--font-family-secondary:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;--font-family-mono:"Fira Code","Courier New",monospace;--border-radius-sm:8px;--border-radius-md:12px;--border-radius-lg:16px;--border-radius-xl:20px;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-xxl:3rem;--transition-fast:0.15s ease;--transition-normal:0.3s ease;--transition-slow:0.5s ease;--transition-bounce:0.3s cubic-bezier(0.68,-0.55,0.265,1.55)}[data-theme=dark]{--bg-primary:#1a1a1a;--bg-secondary:#2a2a2a;--bg-tertiary:#3a3a3a;--text-primary:#fff;--text-secondary:#ccc;--text-muted:#999;--border-color:#444;--shadow-light:#0000004d;--shadow-medium:#0006;--shadow-heavy:#0009}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{background-color:#fff;background-color:var(--bg-primary);color:#333;color:var(--text-primary);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-family:var(--font-family-primary);line-height:1.6;overflow-x:hidden;transition:background-color .3s ease,color .3s ease;transition:background-color var(--transition-normal),color var(--transition-normal)}.app-loading{align-items:center;background:linear-gradient(135deg,#4facfe,#00f2fe);background:var(--primary-gradient);display:flex;height:100vh;justify-content:center;left:0;overflow:hidden;position:fixed;top:0;width:100vw;z-index:9999}.loading-container{position:relative;text-align:center;z-index:2}.loading-logo{align-items:center;animation:logoFloat 3s ease-in-out infinite;display:flex;flex-direction:column;gap:1rem;gap:var(--spacing-md);margin-bottom:2rem;margin-bottom:var(--spacing-xl)}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.loading-logo .logo-icon{align-items:center;animation:iconPulse 2s ease-in-out infinite;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:50%;color:#fff;display:flex;font-size:2.5rem;font-weight:700;height:80px;justify-content:center;width:80px}@keyframes iconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.loading-logo .logo-text{color:#fff;font-size:2.5rem;font-weight:800;letter-spacing:-1px;text-shadow:0 2px 10px #0000004d}.loading-spinner-container{align-items:center;display:flex;flex-direction:column;gap:1rem;gap:var(--spacing-md);margin-bottom:2rem;margin-bottom:var(--spacing-xl)}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-text{color:#fff;font-size:1.1rem;font-weight:500;text-shadow:0 1px 5px #0000004d}.loading-progress{background:#ffffff4d;border-radius:2px;height:4px;overflow:hidden;width:200px}.progress-bar{animation:progressFill 1.5s ease-out;background:#fff;border-radius:2px;height:100%}@keyframes progressFill{0%{width:0}to{width:100%}}.loading-background{height:100%;left:0;overflow:hidden;position:absolute;top:0;width:100%}.floating-shape{animation:floatAround 20s linear infinite;background:#ffffff1a;border-radius:50%;position:absolute}.shape-1{animation-delay:0s;height:100px;left:10%;top:20%;width:100px}.shape-2{animation-delay:-5s;height:60px;right:20%;top:60%;width:60px}.shape-3{animation-delay:-10s;bottom:30%;height:80px;left:70%;width:80px}.shape-4{animation-delay:-15s;height:120px;right:10%;top:10%;width:120px}@keyframes floatAround{0%{transform:translate(0) rotate(0deg)}25%{transform:translate(50px,-50px) rotate(90deg)}50%{transform:translate(-30px,-100px) rotate(180deg)}75%{transform:translate(-80px,30px) rotate(270deg)}to{transform:translate(0) rotate(1turn)}}.app{background-color:#fff;background-color:var(--bg-primary);display:flex;flex-direction:column;min-height:100vh;position:relative;transition:background-color .3s ease;transition:background-color var(--transition-normal)}.app-background{height:100%;left:0;overflow:hidden;position:fixed;top:0;width:100%;z-index:-1}.background-gradient{background:linear-gradient(135deg,#fff,#f8f9fa 25%,#e9ecef 50%,#f8f9fa 75%,#fff);background:linear-gradient(135deg,var(--bg-primary) 0,var(--bg-secondary) 25%,var(--bg-tertiary) 50%,var(--bg-secondary) 75%,var(--bg-primary) 100%);opacity:.8;transition:opacity .3s ease;transition:opacity var(--transition-normal)}.background-gradient,.background-pattern{height:100%;left:0;position:absolute;top:0;width:100%}.background-pattern{animation:patternMove 30s ease-in-out infinite;background-image:radial-gradient(circle at 25% 25%,#4facfe1a 0,#0000 50%),radial-gradient(circle at 75% 75%,#00f2fe1a 0,#0000 50%),radial-gradient(circle at 50% 50%,#4facfe0d 0,#0000 50%);background-size:400px 400px,600px 600px,800px 800px}@keyframes patternMove{0%,to{background-position:0 0,100% 100%,50% 50%}50%{background-position:100% 100%,0 0,25% 75%}}.floating-elements{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.floating-element{animation:floatSlow 25s ease-in-out infinite;background:#4facfe1a;border-radius:50%;position:absolute}.element-1{animation-delay:0s;height:200px;left:5%;top:10%;width:200px}.element-2{animation-delay:-8s;height:150px;right:10%;top:70%;width:150px}.element-3{animation-delay:-16s;bottom:20%;height:100px;left:60%;width:100px}@keyframes floatSlow{0%,to{opacity:.3;transform:translate(0) scale(1)}25%{opacity:.5;transform:translate(30px,-40px) scale(1.1)}50%{opacity:.2;transform:translate(-20px,-80px) scale(.9)}75%{opacity:.4;transform:translate(-50px,20px) scale(1.05)}}.app-header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border-bottom:1px solid #e1e5e9;border-bottom:1px solid var(--border-color);padding:1rem 0;padding:var(--spacing-md) 0;position:sticky;top:0;transition:all .3s ease;transition:all var(--transition-normal);z-index:100}[data-theme=dark] .app-header{background:#1a1a1af2}.header-content{justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 1.5rem;padding:0 var(--spacing-lg)}.app-branding,.app-logo,.header-content{align-items:center;display:flex}.app-logo{color:inherit;gap:1rem;gap:var(--spacing-md);text-decoration:none}.app-logo .logo-icon{align-items:center;background:linear-gradient(135deg,#4facfe,#00f2fe);background:var(--primary-gradient);border-radius:12px;border-radius:var(--border-radius-md);box-shadow:0 4px 12px #4facfe4d;color:#fff;display:flex;font-size:1.5rem;font-weight:700;height:48px;justify-content:center;transition:transform .3s cubic-bezier(.68,-.55,.265,1.55);transition:transform var(--transition-bounce);width:48px}.app-logo:hover .logo-icon{transform:scale(1.05) rotate(5deg)}.logo-text h1{color:#333;color:var(--text-primary);font-size:1.75rem;font-weight:800;letter-spacing:-.5px;margin:0}.logo-tagline{color:#6c757d;color:var(--text-secondary);display:block;font-size:.875rem;font-weight:500;margin-top:-2px}.header-controls{gap:1.5rem;gap:var(--spacing-lg)}.connection-status,.header-controls,.status-indicator{align-items:center;display:flex}.status-indicator{background:#6c757d1a;border-radius:16px;border-radius:var(--border-radius-lg);gap:.5rem;gap:var(--spacing-sm);padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md);transition:all .3s ease;transition:all var(--transition-normal)}.status-indicator.online{background:#28a7451a;color:#28a745;color:var(--success-color)}.status-indicator.offline{background:#ff6b6b1a;color:#ff6b6b;color:var(--danger-color)}.status-dot{animation:statusPulse 2s ease-in-out infinite;background:currentColor;border-radius:50%;height:8px;width:8px}@keyframes statusPulse{0%,to{opacity:1}50%{opacity:.5}}.status-text{font-size:.875rem;font-weight:500}.theme-toggle{background:#e9ecef;background:var(--bg-tertiary);border:2px solid #e1e5e9;border:2px solid var(--border-color);border-radius:20px;cursor:pointer;height:32px;outline:none;position:relative;transition:all .3s ease;transition:all var(--transition-normal);width:60px}.theme-toggle:hover{background:#f8f9fa;background:var(--bg-secondary);border-color:#4facfe;border-color:var(--primary-color)}.theme-toggle:focus{box-shadow:0 0 0 3px #4facfe33}.theme-toggle-track{border-radius:18px;height:100%;overflow:hidden;position:relative;width:100%}.theme-toggle-thumb{align-items:center;background:linear-gradient(135deg,#4facfe,#00f2fe);background:var(--primary-gradient);border-radius:50%;box-shadow:0 2px 8px #0003;display:flex;height:24px;justify-content:center;left:2px;position:absolute;top:2px;transition:transform .3s cubic-bezier(.68,-.55,.265,1.55);transition:transform var(--transition-bounce);width:24px}[data-theme=dark] .theme-toggle-thumb{transform:translateX(26px)}.theme-icon{filter:drop-shadow(0 1px 2px rgba(0,0,0,.3));font-size:.875rem}.app-main{flex:1 1;padding:3rem 0;padding:var(--spacing-xxl) 0;position:relative}.main-container{margin:0 auto;max-width:800px;padding:0 1.5rem;padding:0 var(--spacing-lg)}.app-intro{animation:fadeInUp .8s ease-out;margin-bottom:3rem;margin-bottom:var(--spacing-xxl);text-align:center}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.intro-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4facfe,#00f2fe);background:var(--primary-gradient);-webkit-background-clip:text;background-clip:text;color:#333;color:var(--text-primary);font-size:2.5rem;font-weight:700;line-height:1.2;margin-bottom:1rem;margin-bottom:var(--spacing-md)}.intro-description{color:#6c757d;color:var(--text-secondary);font-size:1.125rem;line-height:1.6;margin:0 auto;max-width:600px}.todo-container{animation:fadeInUp .8s ease-out .2s both}.app-footer{background:#f8f9fa;background:var(--bg-secondary);border-top:1px solid #e1e5e9;border-top:1px solid var(--border-color);margin-top:auto;padding:2rem 0;padding:var(--spacing-xl) 0}.footer-content{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;gap:var(--spacing-md);justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 1.5rem;padding:0 var(--spacing-lg)}.footer-info p{color:#6c757d;color:var(--text-secondary);font-size:.875rem;margin:0}.footer-links{display:flex;gap:1.5rem;gap:var(--spacing-lg)}.footer-link{color:#6c757d;color:var(--text-secondary);font-size:.875rem;font-weight:500;text-decoration:none;transition:color .3s ease;transition:color var(--transition-normal)}.footer-link:hover{color:#4facfe;color:var(--primary-color)}.offline-banner{animation:slideInUp .5s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ff6b6bf2;border-radius:16px;border-radius:var(--border-radius-lg);bottom:1.5rem;bottom:var(--spacing-lg);box-shadow:0 8px 25px #ff6b6b4d;color:#fff;left:50%;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);position:fixed;transform:translateX(-50%);z-index:1000}@keyframes slideInUp{0%{opacity:0;transform:translateX(-50%) translateY(100px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.offline-content{align-items:center;display:flex;gap:.5rem;gap:var(--spacing-sm)}.offline-icon{font-size:1.25rem}.offline-message{font-size:.875rem;font-weight:500}@media (max-width:768px){.header-content{flex-direction:column;gap:1rem;gap:var(--spacing-md);padding:0 1rem;padding:0 var(--spacing-md)}.app-logo .logo-icon{font-size:1.25rem;height:40px;width:40px}.logo-text h1{font-size:1.5rem}.logo-tagline{font-size:.8rem}.header-controls{gap:1rem;gap:var(--spacing-md)}.main-container{padding:0 1rem;padding:0 var(--spacing-md)}.intro-title{font-size:2rem}.intro-description{font-size:1rem}.footer-content{flex-direction:column;padding:0 1rem;padding:0 var(--spacing-md);text-align:center}.offline-banner{left:1rem;left:var(--spacing-md);right:1rem;right:var(--spacing-md);transform:none}.offline-content{flex-direction:column;gap:.25rem;gap:var(--spacing-xs);text-align:center}}@media (max-width:480px){.app-header{padding:.5rem 0;padding:var(--spacing-sm) 0}.header-content{padding:0 .5rem;padding:0 var(--spacing-sm)}.app-logo{gap:.5rem;gap:var(--spacing-sm)}.app-logo .logo-icon{font-size:1.125rem;height:36px;width:36px}.logo-text h1{font-size:1.25rem}.logo-tagline{font-size:.75rem}.theme-toggle{height:28px;width:50px}.theme-toggle-thumb{height:20px;width:20px}[data-theme=dark] .theme-toggle-thumb{transform:translateX(20px)}.theme-icon{font-size:.75rem}.main-container{padding:0 .5rem;padding:0 var(--spacing-sm)}.app-main{padding:2rem 0;padding:var(--spacing-xl) 0}.intro-title{font-size:1.75rem}.intro-description{font-size:.9rem}.footer-content{padding:0 .5rem;padding:0 var(--spacing-sm)}}
/*# sourceMappingURL=main.e0b1ddcf.css.map*/