:root{--removal-duration: .35s;--removal-easing: cubic-bezier(.4, 0, .2, 1)}.todo-item{height:var(--item-height, 80px);overflow:hidden;opacity:1;margin-bottom:8px;border-radius:10px;border-left:4px solid var(--urgency-accent);background:var(--urgency-bg);box-shadow:0 1px 3px #00000014,0 4px 6px #0000000a;transition:height var(--removal-duration) var(--removal-easing),opacity .2s ease,margin-bottom var(--removal-duration) var(--removal-easing),box-shadow .15s ease;cursor:default}.todo-item:hover{box-shadow:0 2px 6px #0000001f,0 6px 12px #0000000f}.todo-item--removing{height:0!important;opacity:0;margin-bottom:0!important}.todo-item--gray{--urgency-accent: #9ca3af;--urgency-bg: #f9fafb;--urgency-text: #6b7280;--urgency-title: #374151}.todo-item--green{--urgency-accent: #22c55e;--urgency-bg: #f0fdf4;--urgency-text: #15803d;--urgency-title: #166534}.todo-item--yellow{--urgency-accent: #eab308;--urgency-bg: #fefce8;--urgency-text: #a16207;--urgency-title: #713f12}.todo-item--red{--urgency-accent: #ef4444;--urgency-bg: #fef2f2;--urgency-text: #dc2626;--urgency-title: #7f1d1d}.todo-item__inner{height:100%;display:flex;flex-direction:column;justify-content:space-between;padding:10px 12px 10px 14px;box-sizing:border-box}.todo-item__header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.todo-item__title{font-size:14px;font-weight:600;color:var(--urgency-title);line-height:1.4;flex:1;min-width:0;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.todo-item__actions{display:flex;gap:2px;flex-shrink:0;opacity:0;transition:opacity .15s ease}.todo-item:hover .todo-item__actions{opacity:1}.todo-item--editing{height:auto!important;overflow:visible;margin-bottom:8px}.todo-item__edit-form{padding:12px 14px;display:flex;flex-direction:column;gap:10px}.todo-item__edit-title{width:100%;border:none;border-bottom:1.5px solid var(--urgency-accent);background:transparent;font-size:14px;font-weight:600;color:var(--urgency-title);font-family:inherit;outline:none;padding:2px 0 4px;box-sizing:border-box}.todo-item__edit-title::placeholder{color:var(--urgency-text);opacity:.5;font-weight:400}.todo-item__edit-row{display:flex;gap:12px;align-items:center}.todo-item__edit-label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--urgency-text);white-space:nowrap}.todo-item__edit-label--deadline{flex:1;min-width:0}.todo-item__edit-input{border:1.5px solid var(--urgency-accent);border-radius:5px;padding:4px 7px;font-size:12px;color:var(--urgency-title);font-family:inherit;background:transparent;outline:none;opacity:.85;transition:opacity .12s ease;box-sizing:border-box}.todo-item__edit-input:focus{opacity:1}input[type=number].todo-item__edit-input{width:64px}input[type=datetime-local].todo-item__edit-input{width:100%}.todo-item__edit-actions{display:flex;justify-content:flex-end;gap:6px}.todo-item__edit-cancel,.todo-item__edit-save{padding:5px 12px;border-radius:6px;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .12s ease,filter .12s ease,transform 80ms ease}.todo-item__edit-cancel{background:transparent;color:var(--urgency-text);border:1.5px solid var(--urgency-accent);opacity:.6}.todo-item__edit-cancel:hover{opacity:1}.todo-item__edit-save{background:var(--urgency-accent);color:#fff;border:none}.todo-item__edit-save:hover:not(:disabled){filter:brightness(1.1)}.todo-item__edit-save:active:not(:disabled){transform:scale(.97)}.todo-item__edit-save:disabled{opacity:.4;cursor:not-allowed}.todo-item__edit-btn,.todo-item__complete-btn,.todo-item__remove-btn{width:24px;height:24px;border:none;border-radius:5px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .12s ease,transform 80ms ease;background:transparent;color:var(--urgency-text);line-height:1}.todo-item__edit-btn:hover{background:#6366f11f;color:#4f46e5}.todo-item__complete-btn:hover{background:#22c55e26;color:#16a34a}.todo-item__remove-btn:hover{background:#ef444426;color:#dc2626}.todo-item__edit-btn:active,.todo-item__complete-btn:active,.todo-item__remove-btn:active{transform:scale(.88)}.todo-item__meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.todo-item__deadline{font-size:12px;color:var(--urgency-text);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.todo-item__complexity{font-size:11px;color:var(--urgency-text);opacity:.7;white-space:nowrap;font-variant-numeric:tabular-nums}.todo-stack{display:flex;flex-direction:column;width:100%}.todo-stack--empty{display:flex;align-items:center;justify-content:center;min-height:120px}.todo-stack__empty-text{font-size:14px;color:#9ca3af;font-style:italic;margin:0}.create-form{background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;padding:12px 14px;transition:border-color .15s ease,box-shadow .15s ease}.create-form:focus-within,.create-form--expanded{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.create-form__title-row{display:flex;align-items:center;gap:8px}.create-form__title-input{flex:1;border:none;outline:none;font-size:14px;font-weight:500;color:#111827;background:transparent;font-family:inherit;padding:0}.create-form__title-input::placeholder{color:#9ca3af;font-weight:400}.create-form__cancel-btn{width:24px;height:24px;border:none;background:transparent;cursor:pointer;font-size:18px;color:#9ca3af;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .12s ease,color .12s ease;line-height:1;padding:0}.create-form__cancel-btn:hover{background:#f3f4f6;color:#374151}.create-form__fields{margin-top:12px;display:flex;flex-direction:column;gap:10px}.create-form__label{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:13px;color:#6b7280}.create-form__label span{white-space:nowrap}.create-form__input{border:1.5px solid #e5e7eb;border-radius:6px;padding:6px 10px;font-size:13px;color:#111827;font-family:inherit;outline:none;transition:border-color .12s ease;background:#f9fafb;min-width:0}.create-form__input:focus{border-color:#6366f1;background:#fff}input[type=number].create-form__input{width:80px}input[type=datetime-local].create-form__input{width:195px}.create-form__submit-btn{margin-top:4px;padding:8px 16px;background:#6366f1;color:#fff;border:none;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .12s ease,transform 80ms ease;align-self:flex-end}.create-form__submit-btn:hover:not(:disabled){background:#4f46e5}.create-form__submit-btn:active:not(:disabled){transform:scale(.97)}.create-form__submit-btn:disabled{opacity:.4;cursor:not-allowed}.archived-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #f3f4f6}.archived-item:last-child{border-bottom:none}.archived-item__content{flex:1;min-width:0}.archived-item__title{display:block;font-size:14px;font-weight:500;color:#374151;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.archived-item__meta{margin-top:2px}.archived-item__meta-text{font-size:12px;color:#9ca3af}.archived-item__restore-btn{flex-shrink:0;width:30px;height:30px;border:1.5px solid #e5e7eb;border-radius:6px;background:#fff;cursor:pointer;font-size:14px;color:#6b7280;display:flex;align-items:center;justify-content:center;transition:border-color .12s ease,background .12s ease,color .12s ease}.archived-item__restore-btn:hover{border-color:#6366f1;background:#eef2ff;color:#4f46e5}.archive-overlay{position:fixed;inset:0;background:#0000;pointer-events:none;transition:background .3s ease;z-index:200}.archive-overlay--open{background:#0000004d;pointer-events:all}.archive-panel{position:absolute;top:0;right:0;bottom:0;width:340px;max-width:90vw;background:#fff;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-4px 0 24px #0000001f}.archive-overlay--open .archive-panel{transform:translate(0)}.archive-panel__header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid #f3f4f6;flex-shrink:0}.archive-panel__title{font-size:16px;font-weight:700;color:#111827;margin:0}.archive-panel__close-btn{width:28px;height:28px;border:none;background:transparent;cursor:pointer;font-size:20px;color:#9ca3af;display:flex;align-items:center;justify-content:center;border-radius:5px;transition:background .12s ease,color .12s ease;line-height:1;padding:0}.archive-panel__close-btn:hover{background:#f3f4f6;color:#374151}.archive-panel__body{flex:1;overflow-y:auto;padding:8px 20px 20px}.archive-panel__empty{font-size:14px;color:#9ca3af;font-style:italic;text-align:center;margin-top:40px}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;min-height:100vh;background:#f1f5f9;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif;color:#111827;-webkit-font-smoothing:antialiased}#root{min-height:100vh}.app{max-width:520px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;padding:0 16px 48px}.app__header{display:flex;align-items:center;justify-content:space-between;padding:24px 0 20px;position:sticky;top:0;background:#f1f5f9;z-index:10}.app__title{font-size:22px;font-weight:800;color:#111827;margin:0;letter-spacing:-.5px}.app__archive-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1.5px solid #e5e7eb;border-radius:8px;background:#fff;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer;font-family:inherit;transition:border-color .12s ease,background .12s ease,color .12s ease}.app__archive-btn:hover{border-color:#6366f1;background:#eef2ff;color:#4f46e5}.app__archive-count{background:#6366f1;color:#fff;font-size:11px;font-weight:700;border-radius:10px;padding:1px 6px;min-width:18px;text-align:center}.app__main{flex:1;display:flex;flex-direction:column}.app__create-wrapper{position:sticky;bottom:16px;margin-top:12px;z-index:10}
