*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #f5f5f7;--color-surface: #ffffff;--color-text: #1d1d1f;--color-text-secondary: #6e6e73;--color-border: #d2d2d7;--color-primary: #007aff;--color-primary-hover: #0056cc;--color-danger: #ff3b30;--color-success: #34c759;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 3px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .1)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased}.app-container{display:flex;flex-direction:column;max-width:640px;height:100dvh;margin:0 auto;padding:16px}.app-viewport{flex:1;min-height:0;overflow:hidden}.app-track{display:flex;height:100%;will-change:transform}.app-view{flex:0 0 100%;min-width:0;height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch}.app-header{display:flex;align-items:center;justify-content:space-between;padding:16px 0;margin-bottom:8px}.app-header h1{font-size:28px;font-weight:700}.saving-indicator{font-size:13px;color:var(--color-text-secondary);animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.loading,.error{display:flex;justify-content:center;align-items:center;min-height:200px;font-size:16px;color:var(--color-text-secondary)}.error{color:var(--color-danger)}.todo-category{--card-padding: 16px;background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:var(--card-padding);margin-bottom:16px}.category-header{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:40px;margin:calc(var(--card-padding) * -1) calc(var(--card-padding) * -1) 12px;padding:10px var(--card-padding);border-radius:var(--radius) var(--radius) 0 0}.category-title{font-size:17px;font-weight:600;color:inherit}.category-color-btn{flex-shrink:0;width:20px;height:20px;padding:0;border-radius:50%;border:2px solid currentColor;background:transparent;opacity:.65;cursor:pointer;transition:opacity .15s,transform .15s}.category-color-btn:hover{opacity:1;transform:scale(1.12)}.color-palette{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px;padding:10px;background:var(--color-bg);border-radius:var(--radius-sm)}.color-option{width:26px;height:26px;padding:0;border-radius:50%;border:2px solid var(--color-surface);box-shadow:0 0 0 1px var(--color-border);cursor:pointer;transition:transform .15s}.color-option:hover{transform:scale(1.12)}.todo-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--color-border);transition:opacity .4s ease,transform .4s ease,max-height .4s ease;max-height:500px;overflow:hidden}.todo-item:last-child{border-bottom:none}.todo-item.completing{opacity:0;transform:translate(60px);max-height:0;padding:0}.todo-item.editing{display:block;padding:12px 0}.todo-check{flex-shrink:0;width:24px;height:24px;margin-top:2px;background:none;border:2px solid var(--color-border);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s,background-color .2s}.todo-check:hover{border-color:var(--color-success);background:#34c7591a}.todo-check:active{background:var(--color-success)}.check-circle{display:block;width:8px;height:8px;border-radius:50%;opacity:0;background:var(--color-success);transition:opacity .15s}.todo-check:hover .check-circle{opacity:1}.todo-body{flex:1;min-width:0;cursor:pointer}.todo-name{display:block;font-size:15px;font-weight:500;touch-action:none;cursor:grab}.todo-name:active{cursor:grabbing}.subtask-preview{list-style:none;margin-top:6px;padding-left:0}.subtask-preview li{font-size:13px;color:var(--color-text-secondary);padding:2px 0 2px 12px;position:relative}.subtask-preview li:before{content:"";position:absolute;left:0;top:50%;width:5px;height:5px;border-radius:50%;background:var(--color-border);transform:translateY(-50%)}.todo-edit-form{display:flex;flex-direction:column;gap:8px}.todo-edit-name{width:100%;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:16px;outline:none;transition:border-color .2s}.todo-edit-name:focus{border-color:var(--color-primary)}.subtask-edit-row{display:flex;align-items:center;gap:8px}.subtask-edit-row input{flex:1;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:14px;outline:none}.subtask-edit-row input:focus{border-color:var(--color-primary)}.subtask-remove{width:28px;height:28px;border:none;background:none;color:var(--color-danger);font-size:18px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center}.subtask-remove:hover{background:#ff3b301a}.btn-add-subtask{align-self:flex-start;background:none;border:none;color:var(--color-primary);font-size:13px;cursor:pointer;padding:4px 0}.btn-add-subtask:hover{text-decoration:underline}.todo-edit-actions{display:flex;gap:8px;margin-top:4px}.btn-add-task,.btn-add-category{display:block;width:100%;padding:10px;border:2px dashed var(--color-border);border-radius:var(--radius-sm);background:none;color:var(--color-text-secondary);font-size:14px;cursor:pointer;transition:border-color .2s,color .2s}.btn-add-task{margin-top:8px}.btn-add-category{margin-top:4px}.btn-add-task:hover,.btn-add-category:hover{border-color:var(--color-primary);color:var(--color-primary)}.add-task-form,.add-category-form{margin-top:8px;display:flex;flex-direction:column;gap:8px}.add-task-form input,.add-category-form input{width:100%;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:16px;outline:none}.add-task-form input:focus,.add-category-form input:focus{border-color:var(--color-primary)}.add-task-actions{display:flex;gap:8px}.btn-save,.btn-cancel{padding:6px 16px;border:none;border-radius:var(--radius-sm);font-size:14px;cursor:pointer;transition:background-color .2s}.btn-save{background:var(--color-primary);color:#fff}.btn-save:hover{background:var(--color-primary-hover)}.btn-cancel{background:var(--color-bg);color:var(--color-text-secondary)}.btn-cancel:hover{background:var(--color-border)}.app-nav{display:flex;flex-shrink:0;gap:4px;padding:4px;margin-bottom:8px;background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow)}.nav-tab{flex:1;padding:10px;border:none;border-radius:var(--radius-sm);background:none;color:var(--color-text-secondary);font-size:15px;font-weight:600;cursor:pointer;transition:background-color .2s,color .2s}.nav-tab:hover{color:var(--color-text)}.nav-tab.active{background:var(--color-primary);color:#fff}.memo-pinned{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px 16px;margin-bottom:16px}.memo-section-title{font-size:13px;font-weight:600;color:var(--color-text-secondary);margin-bottom:8px}.memo-tree{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:8px}.memo-empty{padding:16px;text-align:center;font-size:14px;color:var(--color-text-secondary)}.memo-file-row{display:flex;align-items:center;gap:4px}.memo-file-name{flex:1;display:flex;align-items:center;gap:8px;min-width:0;padding:8px;border:none;background:none;color:var(--color-text);font-size:15px;text-align:left;cursor:pointer;border-radius:var(--radius-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.memo-file-name:hover{background:var(--color-bg)}.memo-icon{flex-shrink:0}.memo-pin-btn{flex-shrink:0;width:32px;height:32px;border:none;background:none;color:var(--color-text-secondary);font-size:16px;cursor:pointer;border-radius:50%;transition:background-color .2s,color .2s}.memo-pin-btn:hover{background:var(--color-bg)}.memo-pin-btn.pinned{color:#fc0}.memo-folder-row{display:flex;align-items:center;gap:8px;width:100%;padding:8px;border:none;background:none;color:var(--color-text);font-size:15px;font-weight:500;text-align:left;cursor:pointer;border-radius:var(--radius-sm)}.memo-folder-row:hover{background:var(--color-bg)}.memo-caret{flex-shrink:0;width:12px;color:var(--color-text-secondary);font-size:12px}.memo-new-actions{display:flex;flex-wrap:wrap;gap:8px;padding:8px}.memo-new-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-primary);font-size:14px;font-weight:600;cursor:pointer;transition:border-color .2s,background-color .2s}.memo-new-btn:hover{border-color:var(--color-primary);background:var(--color-surface)}.memo-new-btn:active{background:var(--color-bg)}.memo-new-form{display:flex;flex-direction:column;gap:8px;padding:8px}.memo-new-form input{width:100%;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:16px;outline:none}.memo-new-form input:focus{border-color:var(--color-primary)}.memo-new-form-actions{display:flex;gap:8px}.memo-editor{display:flex;flex-direction:column;gap:12px}.memo-editor-header{display:flex;align-items:center;gap:8px}.memo-back-btn{border:none;background:none;color:var(--color-primary);font-size:15px;cursor:pointer;padding:6px 4px}.memo-back-btn:hover{text-decoration:underline}.memo-editor-title{flex:1;min-width:0;font-size:16px;font-weight:600;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-save:disabled{opacity:.5;cursor:default}.memo-textarea{width:100%;min-height:60dvh;padding:16px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:15px;line-height:1.7;resize:vertical;outline:none}.memo-textarea:focus{border-color:var(--color-primary)}@media(max-width:480px){.app-container{padding:12px}.app-header h1{font-size:24px}.todo-category{--card-padding: 12px}.todo-name{font-size:14px}}@media(min-width:768px){.app-container{padding:24px}}
