*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-tap-highlight-color:transparent}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background-color:#f5f5f5;color:#333;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}@media screen and (max-width: 375px){html{font-size:16px}}@media screen and (min-width: 376px) and (max-width: 414px){html{font-size:17px}}@media screen and (min-width: 415px){html{font-size:18px}}.page{min-height:100vh;display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom)}.nav-bar{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;padding-top:calc(.75rem + env(safe-area-inset-top));background-color:#fff;position:sticky;top:0;z-index:100}.nav-title{font-size:1.375rem;font-weight:700;color:#000}.nav-right{display:flex;align-items:center;gap:.5rem}.settings-btn{width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:#666;background:none;border:none;cursor:pointer}.sync-status{display:flex;align-items:center;padding:.25rem .5rem;border-radius:1rem;font-size:.75rem}.sync-status.online{background-color:#07c1601a}.sync-status.offline{background-color:#ff6b6b1a}.sync-icon{width:.5rem;height:.5rem;border-radius:50%;margin-right:.25rem}.sync-icon.online{background-color:#07c160}.sync-icon.offline{background-color:#ff6b6b}.sync-text{font-size:.75rem;color:#07c160}.sync-status.offline .sync-text{color:#ff6b6b}.input-section{display:flex;align-items:center;padding:.75rem 1rem;gap:.5rem;background-color:#fff;margin:.5rem 1rem;border-radius:1rem;box-shadow:0 1px 6px #0000000a}.input-area{flex:1;min-height:2.5rem;max-height:5rem;font-size:1rem;line-height:1.5;color:#333;padding:.5rem 0;border:none;outline:none;background:transparent;resize:none}.input-area::placeholder{color:#bbb}.add-btn{width:4rem;height:2.25rem;background-color:#07c160;color:#fff;font-size:.875rem;font-weight:500;border-radius:1.125rem;border:none;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}.add-btn:active{opacity:.8}.tab-bar{white-space:nowrap;padding:0 .5rem;background-color:#f5f5f5;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.tab-bar::-webkit-scrollbar{display:none}.tab-list{display:inline-flex;padding:0 .5rem}.tab-item{display:inline-flex;flex-direction:column;align-items:center;padding:.75rem 1rem;position:relative;cursor:pointer}.tab-text{font-size:.875rem;color:#999;transition:color .2s}.tab-item.active .tab-text{color:#07c160;font-weight:600;font-size:.9375rem}.tab-underline{position:absolute;bottom:.375rem;left:50%;transform:translate(-50%);width:1.25rem;height:.1875rem;background-color:#07c160;border-radius:.125rem;opacity:0;transition:opacity .2s}.tab-item.active .tab-underline{opacity:1}.todo-list{flex:1;padding:0 1rem 1rem;overflow-y:auto;touch-action:pan-y;-webkit-overflow-scrolling:touch}.todo-item{background-color:#fff;border-radius:.75rem;padding:1rem;margin-bottom:.75rem;display:flex;align-items:flex-start;gap:.75rem;box-shadow:0 1px 4px #0000000a;cursor:pointer;user-select:none;-webkit-user-select:none;transition:transform .1s}.todo-item:active{transform:scale(.99)}.todo-checkbox{width:1.375rem;height:1.375rem;border:2px solid #ddd;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.125rem;cursor:pointer;transition:all .2s}.todo-checkbox.checked{background-color:#07c160;border-color:#07c160}.todo-checkbox:after{content:"";width:.375rem;height:.625rem;border-right:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(45deg) translate(-1px,-1px);opacity:0;transition:opacity .2s}.todo-checkbox.checked:after{opacity:1}.todo-content{flex:1;min-width:0}.todo-text{font-size:1rem;color:#333;line-height:1.5;word-break:break-all}.todo-text.completed{color:#999;text-decoration:line-through}.todo-meta{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;flex-wrap:wrap;justify-content:space-between}.todo-tags-right{display:flex;align-items:center;gap:.5rem;margin-left:auto}.todo-time{font-size:.75rem;color:#07c160;background-color:#07c1601a;padding:.125rem .5rem;border-radius:.25rem;cursor:pointer;transition:background-color .2s,transform .1s}.todo-time:active{background-color:#07c16033;transform:scale(.98)}.todo-category{font-size:.75rem;color:#666;background-color:#f5f5f5;padding:.125rem .5rem;border-radius:.25rem}.todo-tag{font-size:.75rem;padding:.125rem .5rem;border-radius:.25rem}.todo-tag.work{color:#1890ff;background-color:#1890ff1a}.todo-tag.parenting{color:#fa8c16;background-color:#fa8c161a}.first-tip{position:fixed;top:20%;left:50%;transform:translate(-50%);background-color:#000000b3;color:#fff;padding:.75rem 1.5rem;border-radius:1.5rem;font-size:.875rem;z-index:1000;animation:fadeInOut 3s ease forwards}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%) translateY(-10px)}10%{opacity:1;transform:translate(-50%) translateY(0)}80%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-10px)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 0;color:#999}.loading-spinner{width:2rem;height:2rem;border:2px solid #f0f0f0;border-top-color:#07c160;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:.75rem}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 0;color:#999}.empty-icon{font-size:3rem;margin-bottom:.75rem}.empty-text{font-size:.875rem}.action-sheet-mask{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:1000;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s ease}.action-sheet-mask.show{opacity:1;pointer-events:auto}.action-sheet{width:100%;background-color:#fff;border-radius:1rem 1rem 0 0;padding-bottom:env(safe-area-inset-bottom);transform:translateY(100%);transition:transform .2s ease;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.action-sheet-mask.show .action-sheet{transform:translateY(0)}.action-sheet-item{padding:1rem;text-align:center;font-size:1rem;color:#333;border-bottom:1px solid #f0f0f0;cursor:pointer;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.action-sheet-item:last-child{border-bottom:none}.action-sheet-item.danger{color:#ff3b30}.action-sheet-item:active{background-color:#f5f5f5}.action-sheet-cancel{margin-top:.5rem;border-top:.5rem solid #f5f5f5;font-weight:600}.modal-mask{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s ease}.modal-mask.show{opacity:1;pointer-events:auto}.modal-content{width:80%;max-width:320px;background-color:#fff;border-radius:.75rem;overflow:hidden;transform:scale(.9);transition:transform .2s ease}.modal-mask.show .modal-content{transform:scale(1)}.modal-header{padding:1.25rem 1rem .5rem;text-align:center}.modal-title{font-size:1.0625rem;font-weight:600;color:#1a1a1a}.modal-body{padding:.5rem 1.25rem 1.25rem;text-align:center}.modal-text{font-size:.9375rem;color:#666;line-height:1.5}.modal-footer{display:flex;border-top:1px solid #f0f0f0}.modal-btn{flex:1;padding:.875rem;text-align:center;font-size:1rem;cursor:pointer;border:none;background:none}.modal-btn.cancel{color:#666;border-right:1px solid #f0f0f0}.modal-btn.confirm{color:#07c160;font-weight:500}.modal-btn.danger{color:#ff3b30}.modal-btn:active{background-color:#f5f5f5}.time-picker-input{width:100%;padding:.75rem;font-size:1.25rem;text-align:center;border:1px solid #e0e0e0;border-radius:.5rem;outline:none}.time-picker-input:focus{border-color:#07c160}.undo-toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:.75rem 1.25rem;border-radius:1.5rem;display:flex;align-items:center;gap:.75rem;z-index:1001;font-size:.875rem;box-shadow:0 4px 12px #00000026}.undo-btn{color:#07c160;font-weight:500;cursor:pointer;padding:.25rem .5rem}.settings-page{min-height:100vh;background-color:#f5f5f5}.settings-header{display:flex;align-items:center;padding:.75rem 1rem;padding-top:calc(.75rem + env(safe-area-inset-top));background-color:#fff}.back-btn{width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:#333;background:none;border:none;cursor:pointer}.settings-title{flex:1;font-size:1.0625rem;font-weight:600;text-align:center;margin-right:2.25rem}.settings-list{padding:.75rem}.settings-item{background-color:#fff;padding:1rem;border-bottom:1px solid #f0f0f0}.settings-item:first-child{border-radius:.75rem .75rem 0 0}.settings-item:last-child{border-radius:0 0 .75rem .75rem;border-bottom:none}.settings-item:only-child{border-radius:.75rem;border-bottom:none}.item-header{margin-bottom:.75rem}.item-title{font-size:.9375rem;color:#1a1a1a;font-weight:500}.item-row{display:flex;justify-content:space-between;align-items:center}.role-options{display:flex;gap:.75rem}.role-btn{flex:1;min-width:5rem;height:2.5rem;line-height:2.5rem;text-align:center;font-size:.875rem;color:#666;background-color:#f5f5f5;border-radius:.5rem;border:none;cursor:pointer}.role-btn.active{background-color:#07c160;color:#fff}.switch{position:relative;width:3rem;height:1.75rem;background-color:#e0e0e0;border-radius:.875rem;cursor:pointer;transition:background-color .2s}.switch.checked{background-color:#07c160}.switch-thumb{position:absolute;top:.125rem;left:.125rem;width:1.5rem;height:1.5rem;background-color:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 2px 4px #0000001a}.switch.checked .switch-thumb{transform:translate(1.25rem)}.guide-btn{margin:1.25rem 1rem 1.5rem;text-align:center;font-size:.9375rem;color:#07c160;padding:.875rem 1rem;cursor:pointer;background-color:#fff;border-radius:.75rem;border:1px solid rgba(7,193,96,.25);box-shadow:0 3px 12px #07c1601f;font-weight:600;transition:transform .15s ease,box-shadow .2s ease,background-color .2s ease;position:relative}.guide-btn:after{content:"点击查看";margin-left:.5rem;font-size:.75rem;color:#34c979;font-weight:500}.guide-btn:active{transform:scale(.98);background-color:#f3fff8;box-shadow:0 2px 8px #07c16029}.guide-modal-body{padding:.5rem 1.5rem 1rem;max-height:60vh;overflow-y:auto}.guide-line{font-size:.875rem;color:#333;line-height:2}.guide-divider{height:1px;background-color:#eee;margin:.75rem 0 .5rem}.guide-section{font-size:.9375rem;font-weight:600;color:#07c160;line-height:2.2}.guide-confirm{text-align:center;font-size:1rem;color:#07c160;font-weight:600;padding:.75rem 0 1rem;border-top:1px solid #f0f0f0;cursor:pointer;background:linear-gradient(180deg,#fff,#f3fff8)}.guide-confirm:active{background:#e9fff2}.category-options{display:flex;flex-direction:column;gap:12px;padding:8px 0}.category-option{padding:12px 16px;background:#f5f5f5;border-radius:12px;text-align:center;font-size:16px;cursor:pointer;transition:background .2s}.category-option.selected{background:#07c160;color:#fff}.category-option:active{opacity:.8}.guide-author{font-size:.75rem;color:#999;text-align:center;margin-top:1rem}.category-options{display:flex;flex-direction:column;gap:.5rem}.category-option{padding:.75rem;text-align:center;font-size:1rem;color:#333;background-color:#f5f5f5;border-radius:.5rem;cursor:pointer;border:2px solid transparent}.category-option.selected{border-color:#07c160;background-color:#07c1601a;color:#07c160}.category-option:active{background-color:#e8e8e8}.pull-refresh{display:flex;align-items:center;justify-content:center;padding:.75rem;color:#999;font-size:.875rem;flex-shrink:0;min-height:0}.pull-refresh-icon{width:1rem;height:1rem;border:2px solid #ddd;border-top-color:#07c160;border-radius:50%;margin-right:.5rem}.pull-refresh-icon.spinning{animation:spin .8s linear infinite}
