*,*:before,*:after{box-sizing:border-box}*{margin:0}body{line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}#root{isolation:isolate}.dark{color-scheme:dark}@media(max-width:480px){:root{--container-max-width: 100vw;--padding-x: 1rem;--padding-y: .75rem}}@media(min-width:481px)and (max-width:768px){:root{--container-max-width: 100vw;--padding-x: 1.5rem;--padding-y: 1rem}}@media(min-width:769px)and (max-width:1024px){:root{--container-max-width: 768px;--padding-x: 2rem;--padding-y: 1.5rem}}@media(min-width:1025px)and (max-width:1440px){:root{--container-max-width: 1024px;--padding-x: 2.5rem;--padding-y: 2rem}}@media(min-width:1441px){:root{--container-max-width: 1280px;--padding-x: 3rem;--padding-y: 2.5rem}}:root{--color-bg: #f9fafb;--color-bg-dark: #000000;--color-surface: #ffffff;--color-surface-dark: #1f2937;--color-surface-2: #f3f4f6;--color-surface-2-dark: #374151;--color-border: #d1d5db;--color-border-dark: #374151;--color-text: #111827;--color-text-dark: #f9fafb;--color-text-secondary: #6b7280;--color-text-secondary-dark: #9ca3af;--color-primary: #2563eb;--color-primary-dark: #3b82f6;--color-secondary: #64748b;--color-danger: #dc2626;--color-success: #059669;--color-warning: #d97706}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}button:focus,input:focus,textarea:focus,select:focus{outline:none}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}h1{font-size:1.875rem;font-weight:700;line-height:1.2}h2{font-size:1.5rem;font-weight:600;line-height:1.3}p,span,div{font-size:1rem;line-height:1.5}@media(max-width:480px){h1{font-size:1.5rem}h2{font-size:1.25rem}p,span,div{font-size:.875rem}}.app{height:100dvh;height:100vh;display:flex;flex-direction:column;background-color:var(--color-bg);transition:background-color .3s ease;overflow:hidden}.dark .app{background-color:var(--color-bg-dark)}.header{position:sticky;top:0;z-index:10;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:all .3s ease;flex-shrink:0}.dark .header{background-color:var(--color-surface-dark);border-bottom-color:var(--color-border-dark)}.header-content{max-width:var(--container-max-width);margin:0 auto;padding:1rem var(--padding-x)}@media(max-width:768px){.header-content{padding:.75rem var(--padding-x)}}.main{flex:1;display:flex;flex-direction:column;max-width:var(--container-max-width);width:100%;margin:0 auto;padding:var(--padding-y) var(--padding-x);overflow:hidden;min-height:0}.todo-section{margin-bottom:1.25rem}@media(max-width:480px){.todo-section{margin-bottom:1rem}}.controls{margin-bottom:1.25rem;display:flex;flex-direction:column;justify-content:space-between;align-items:stretch;gap:.75rem}@media(min-width:641px){.controls{flex-direction:row;align-items:center}}@media(max-width:480px){.controls{margin-bottom:1rem}}.clear-actions-group{display:flex;justify-content:center;width:100%}@media(min-width:641px){.clear-actions-group{justify-content:flex-end;width:auto}}.clear-buttons{display:flex;gap:.5rem;justify-content:center}.todo-list-container{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;width:100%;scrollbar-gutter:stable}.todo-list-container::-webkit-scrollbar{width:6px}.todo-list-container::-webkit-scrollbar-track{background:transparent}.todo-list-container::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.dark .todo-list-container::-webkit-scrollbar-thumb{background:var(--color-text-secondary-dark)}.todo-list-container::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.dark .todo-list-container::-webkit-scrollbar-thumb:hover{background:var(--color-text-dark)}.footer{margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--color-border);text-align:center;font-size:.875rem;color:var(--color-text-secondary)}.dark .footer{border-top-color:var(--color-border-dark);color:var(--color-text-secondary-dark)}@media(max-width:480px){.footer{margin-top:1rem;padding-top:.75rem;font-size:.75rem}}.header-title{font-size:1.5rem;font-weight:700;color:var(--color-text);margin-bottom:.125rem;line-height:1.2}.dark .header-title{color:var(--color-text-dark)}.header-subtitle{font-size:.8125rem;color:var(--color-text-secondary);line-height:1.4}.dark .header-subtitle{color:var(--color-text-secondary-dark)}@media(max-width:768px){.header-title{font-size:1.375rem}.header-subtitle{font-size:.75rem}}@media(max-width:480px){.header-title{font-size:1.25rem}.header-subtitle{display:none}}.header-layout{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}@media(max-width:768px){.header-layout{margin-bottom:.75rem}}.progress-section{display:flex;flex-direction:column;gap:.375rem;font-size:.8125rem}@media(max-width:768px){.progress-section{gap:.25rem;font-size:.75rem}}.progress-label{display:flex;justify-content:space-between;color:var(--color-text-secondary)}.dark .progress-label{color:var(--color-text-secondary-dark)}.progress-bar{width:100%;height:6px;background-color:var(--color-surface-2);border-radius:3px;overflow:hidden}.dark .progress-bar{background-color:var(--color-surface-2-dark)}@media(max-width:768px){.progress-bar{height:5px}}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);border-radius:3px;transition:width .5s ease}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;padding:.5rem;background-color:var(--color-surface-2);border-radius:.5rem;color:var(--color-text-secondary);border:none;cursor:pointer;transition:all .2s ease;min-width:44px;min-height:44px;line-height:1}.dark .theme-toggle{background-color:var(--color-surface-2-dark);color:var(--color-text-secondary-dark)}.theme-toggle svg{display:block}.theme-toggle:hover{background-color:var(--color-border);transform:scale(1.1)}.dark .theme-toggle:hover{background-color:var(--color-border-dark)}.theme-toggle:active{transform:scale(1.05)}@media(max-width:480px){.theme-toggle{padding:.5rem;min-width:44px;min-height:44px}.theme-toggle svg{width:1.25rem;height:1.25rem}}.todo-input-form{width:100%}.todo-input{width:100%;padding:.75rem 1rem;font-size:1rem;border:2px solid var(--color-border);border-radius:.75rem;background-color:var(--color-surface-2);color:var(--color-text);transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.todo-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.dark .todo-input{background-color:var(--color-surface-2-dark);border-color:var(--color-border-dark);color:var(--color-text-dark)}.dark .todo-input:focus{box-shadow:0 0 0 3px #3b82f61a}@media(max-width:480px){.todo-input{padding:.625rem .875rem;font-size:.875rem}}input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:6px;background:var(--color-surface-2);border-radius:3px;outline:none;cursor:pointer}.dark input[type=range]{background:var(--color-surface-2-dark)}input[type=range]::-webkit-slider-track{width:100%;height:6px;background:var(--color-surface-2);border-radius:3px}.dark input[type=range]::-webkit-slider-track{background:var(--color-surface-2-dark)}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;background:var(--color-primary);border-radius:50%;cursor:pointer;border:2px solid var(--color-surface);box-shadow:0 2px 4px #0003;transition:all .2s ease}.dark input[type=range]::-webkit-slider-thumb{background:var(--color-primary-dark);border-color:var(--color-surface-dark)}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 3px 6px #0000004d}input[type=range]::-moz-range-track{width:100%;height:6px;background:var(--color-surface-2);border-radius:3px}.dark input[type=range]::-moz-range-track{background:var(--color-surface-2-dark)}input[type=range]::-moz-range-thumb{width:18px;height:18px;background:var(--color-primary);border-radius:50%;cursor:pointer;border:2px solid var(--color-surface);box-shadow:0 2px 4px #0003;transition:all .2s ease}.dark input[type=range]::-moz-range-thumb{background:var(--color-primary-dark);border-color:var(--color-surface-dark)}input[type=range]::-moz-range-thumb:hover{transform:scale(1.1);box-shadow:0 3px 6px #0000004d}input[type=range]:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.625rem 1rem;font-size:.875rem;font-weight:500;border-radius:.5rem;border:none;cursor:pointer;transition:all .2s ease;min-width:44px;min-height:44px;gap:.5rem;text-decoration:none;line-height:1}.btn svg{display:block;flex-shrink:0}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.btn-secondary{background-color:var(--color-surface-2);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background-color:var(--color-border)}.dark .btn-secondary{background-color:var(--color-surface-2-dark);color:var(--color-text-dark);border-color:var(--color-border-dark)}.dark .btn-secondary:hover:not(:disabled){background-color:var(--color-border-dark)}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background-color:var(--color-danger);filter:brightness(.9);transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;background-color:transparent;color:var(--color-text-secondary);border:none;padding:.5rem;min-width:44px;min-height:44px;line-height:1}.btn-ghost svg{display:block}.btn-ghost:hover:not(:disabled){background-color:#0000000d;color:var(--color-text)}.dark .btn-ghost:hover:not(:disabled){background-color:#ffffff0d;color:var(--color-text-dark)}.filter-buttons{display:flex;flex-direction:column;gap:.5rem;justify-content:center}@media(min-width:641px){.filter-buttons{flex-direction:row;gap:.75rem}}.filter-btn{display:inline-flex;align-items:center;justify-content:center;padding:.625rem 1.25rem;border-radius:.5rem;font-weight:500;transition:all .2s ease;border:none;cursor:pointer;font-size:1rem;min-width:44px;min-height:44px;line-height:1}.filter-btn:not(.filter-btn-active){background-color:var(--color-surface-2);color:var(--color-text)}.filter-btn:not(.filter-btn-active):hover{background-color:var(--color-border);transform:scale(1.05)}.dark .filter-btn:not(.filter-btn-active){background-color:var(--color-surface-2-dark);color:var(--color-text-dark)}.dark .filter-btn:not(.filter-btn-active):hover{background-color:var(--color-border-dark)}.filter-btn-active{background-color:var(--color-primary);color:#fff;transform:scale(1.05);box-shadow:0 4px 12px #2563eb4d}.todo-item{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;padding:.75rem 1rem;background-color:var(--color-surface);border-radius:.75rem;box-shadow:0 1px 3px #0000001a;transition:all .3s ease;border:1px solid var(--color-border);position:relative;cursor:pointer;-webkit-user-select:none;user-select:none;min-height:56px}.todo-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.dark .todo-item{background-color:var(--color-surface-dark);border-color:var(--color-border-dark)}.todo-item.completed{opacity:.7}.todo-checkbox{width:1.25rem;height:1.25rem;border:2px solid var(--color-border);border-radius:4px;background-color:transparent;cursor:pointer;transition:all .2s ease;min-width:20px;flex-shrink:0}.todo-checkbox:checked{background-color:var(--color-primary);border-color:var(--color-primary)}.todo-checkbox:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.todo-text-container{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem;overflow:hidden}.todo-text{font-size:1rem;color:var(--color-text);line-height:1.5;cursor:text;-webkit-user-select:text;user-select:text;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}.todo-text.completed{text-decoration:line-through;color:var(--color-text-secondary);cursor:default}.dark .todo-text{color:var(--color-text-dark)}.dark .todo-text.completed{color:var(--color-text-secondary-dark)}.todo-timestamp{font-size:.75rem;color:var(--color-text-secondary);display:block}.dark .todo-timestamp{color:var(--color-text-secondary-dark)}.todo-edit-input{flex:1;padding:.25rem .5rem;font-size:1rem;border:2px solid var(--color-primary);border-radius:.25rem;background-color:var(--color-surface-2);color:var(--color-text)}.dark .todo-edit-input{background-color:var(--color-surface-2-dark);color:var(--color-text-dark)}.todo-actions{display:flex;gap:.25rem;opacity:0;transition:opacity .2s ease;flex-shrink:0;align-items:center}.todo-item:hover .todo-actions,.todo-item:focus-within .todo-actions{opacity:1}.todo-btn-edit,.todo-btn-delete{display:inline-flex;align-items:center;justify-content:center;padding:.5rem;border:none;border-radius:.5rem;cursor:pointer;transition:all .2s ease;min-width:44px;min-height:44px;width:44px;height:44px;line-height:1;background-color:transparent;flex-shrink:0}.todo-btn-edit svg,.todo-btn-delete svg{display:block;width:1rem;height:1rem}.todo-btn-edit{color:var(--color-primary)}.todo-btn-edit:hover{background-color:#2563eb1a}.dark .todo-btn-edit:hover{background-color:#3b82f61a}.todo-btn-delete{color:var(--color-danger)}.todo-btn-delete:hover{background-color:#dc26261a}.dark .todo-btn-delete:hover{background-color:#ef44441a}.todo-list{display:flex;flex-direction:column;gap:.5rem;width:100%;max-width:100%}.empty-state{text-align:center;padding:3rem 1rem;color:var(--color-text-secondary)}.empty-state-icon{width:4rem;height:4rem;margin:0 auto 1rem;opacity:.3}.empty-state-text{font-size:1.125rem}@media(max-width:480px){.empty-state{padding:2rem 1rem}.empty-state-icon{width:3rem;height:3rem}.empty-state-text{font-size:1rem}}.toast{position:fixed;bottom:1rem;right:1rem;background-color:var(--color-surface-dark);color:var(--color-text-dark);padding:.75rem 1.25rem;border-radius:.5rem;box-shadow:0 10px 25px #0003;border:1px solid var(--color-border-dark);animation:fade-in .3s ease-out;z-index:50;max-width:calc(100vw - 2rem)}.toast-message{font-weight:500;font-size:.875rem}@keyframes fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:40;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fade-in .2s ease-out}.dark .modal-overlay{background-color:#000000b3}.modal-content{background-color:var(--color-surface);border-radius:.75rem;padding:2rem;max-width:28rem;width:100%;box-shadow:0 20px 40px #00000026;border:1px solid var(--color-border);animation:slide-up .3s ease-out}.dark .modal-content{background-color:var(--color-surface-dark);border-color:var(--color-border-dark);box-shadow:0 20px 40px #0006}@keyframes slide-up{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-title{font-size:1.5rem;font-weight:700;margin-bottom:1rem;color:var(--color-text)}.dark .modal-title{color:var(--color-text-dark)}.modal-message{font-size:1rem;line-height:1.6;margin-bottom:1.5rem;color:var(--color-text-secondary)}.dark .modal-message{color:var(--color-text-secondary-dark)}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem}.icon-sm{width:1rem;height:1rem}.progress-percentage{font-weight:600;color:var(--color-primary)}.dark .progress-percentage{color:var(--color-primary-dark)}.suggestions-container{padding:2rem 1rem;text-align:center;animation:fade-in .4s ease-out}.suggestions-title{font-size:1.5rem;font-weight:700;color:var(--color-text);margin-bottom:.5rem}.dark .suggestions-title{color:var(--color-text-dark)}.suggestions-subtitle{font-size:.9375rem;color:var(--color-text-secondary);margin-bottom:2rem;line-height:1.5}.dark .suggestions-subtitle{color:var(--color-text-secondary-dark)}.suggestions-grid{display:flex;flex-direction:column;gap:.75rem;max-width:600px;margin:0 auto}@media(max-width:480px){.suggestions-container{padding:1.5rem .5rem}.suggestions-title{font-size:1.25rem}.suggestions-subtitle{font-size:.875rem;margin-bottom:1.5rem}.suggestions-grid{gap:.625rem}}.suggestion-chip{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.875rem 1rem;background-color:var(--color-surface);border:2px solid var(--color-border);border-radius:.75rem;color:var(--color-text);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:left;min-height:56px;line-height:1.4;box-shadow:0 1px 3px #0000000d}.dark .suggestion-chip{background-color:var(--color-surface-dark);border-color:var(--color-border-dark);color:var(--color-text-dark);box-shadow:0 1px 3px #0003}.suggestion-chip:hover{border-color:var(--color-primary);background-color:var(--color-surface-2);box-shadow:0 4px 12px #2563eb26}.dark .suggestion-chip:hover{background-color:var(--color-surface-2-dark);box-shadow:0 4px 12px #3b82f633}.suggestion-chip:active{transform:scale(.98)}.suggestion-chip:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.suggestion-text{flex:1;min-width:0}.suggestion-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:2rem;height:2rem;background-color:var(--color-primary);color:#fff;border-radius:50%;font-size:1.25rem;font-weight:600;line-height:1;transition:background-color .2s ease;will-change:background-color}.suggestion-icon span{display:block;line-height:1}.suggestion-chip:hover .suggestion-icon,.dark .suggestion-icon{background-color:var(--color-primary-dark)}.dark .suggestion-chip:hover .suggestion-icon{background-color:var(--color-primary)}.mobile-only{display:none!important}.desktop-only{display:flex!important}@media(max-width:768px){.mobile-only{display:flex!important}.desktop-only{display:none!important}}.mobile-menu-trigger{display:inline-flex;align-items:center;justify-content:center;padding:.625rem;background-color:var(--color-surface-2);border:1px solid var(--color-border);border-radius:.5rem;color:var(--color-text);cursor:pointer;transition:all .2s ease;min-width:44px;min-height:44px;line-height:1}.dark .mobile-menu-trigger{background-color:var(--color-surface-2-dark);border-color:var(--color-border-dark);color:var(--color-text-dark)}.mobile-menu-trigger:hover{background-color:var(--color-border)}.dark .mobile-menu-trigger:hover{background-color:var(--color-border-dark)}.mobile-menu-trigger:active{transform:scale(.95)}.mobile-menu-overlay{position:fixed;inset:0;background-color:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:100;display:flex;align-items:flex-end;animation:fade-in .2s ease-out}.dark .mobile-menu-overlay{background-color:#000000b3}.mobile-menu{background-color:var(--color-surface);border-radius:1.5rem 1.5rem 0 0;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 -10px 40px #0003;animation:slide-up-mobile .3s ease-out}.dark .mobile-menu{background-color:var(--color-surface-dark);box-shadow:0 -10px 40px #00000080}@keyframes slide-up-mobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border)}.dark .mobile-menu-header{border-bottom-color:var(--color-border-dark)}.mobile-menu-header h3{font-size:1.125rem;font-weight:600;color:var(--color-text)}.dark .mobile-menu-header h3{color:var(--color-text-dark)}.mobile-menu-close{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:none;background:transparent;color:var(--color-text-secondary);font-size:2rem;line-height:1;cursor:pointer;border-radius:50%;transition:all .2s ease}.dark .mobile-menu-close{color:var(--color-text-secondary-dark)}.mobile-menu-close:hover{background-color:var(--color-surface-2)}.dark .mobile-menu-close:hover{background-color:var(--color-surface-2-dark)}.mobile-menu-content{padding:.5rem}.mobile-menu-item{display:flex;align-items:center;gap:1rem;width:100%;padding:1rem 1.25rem;background:transparent;border:none;border-radius:.75rem;color:var(--color-text);font-size:1rem;font-weight:500;text-align:left;cursor:pointer;transition:all .2s ease;min-height:56px}.dark .mobile-menu-item{color:var(--color-text-dark)}.mobile-menu-item:hover{background-color:var(--color-surface-2)}.dark .mobile-menu-item:hover{background-color:var(--color-surface-2-dark)}.mobile-menu-item:active{transform:scale(.98)}.mobile-menu-item-danger{color:var(--color-danger)}.mobile-menu-item-danger:hover{background-color:#dc26261a}.dark .mobile-menu-item-danger:hover{background-color:#ef44441a}@media(max-width:768px){.controls{flex-direction:row;justify-content:space-between;align-items:center}.filter-buttons{flex-direction:row;flex:1}.todo-item{padding:.875rem .75rem;gap:.625rem;grid-template-columns:auto 1fr auto}.todo-actions{opacity:1}.todo-text{font-size:.9375rem}.todo-timestamp{font-size:.6875rem}}@media(max-width:480px){.mobile-menu-header{padding:1rem 1.25rem}.mobile-menu-item{padding:.875rem 1rem;min-height:52px}.todo-item{padding:.75rem .625rem;gap:.5rem;min-height:52px}.todo-checkbox{width:1.125rem;height:1.125rem}.todo-btn-edit,.todo-btn-delete{min-width:40px;min-height:40px;width:40px;height:40px;padding:.375rem}}*{max-width:100%}html,body{overflow-x:hidden}
