*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Yu Gothic,sans-serif;background:#f2f2f7;color:#1c1c1e;max-width:600px;margin:0 auto;min-height:100vh}.header{background:#fff;padding:16px 20px 12px;border-bottom:1px solid #e5e5ea;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header h1{font-size:20px;font-weight:700}.tabs{display:flex;gap:8px;padding:12px 16px;background:#f2f2f7;position:-webkit-sticky;position:sticky;top:53px;z-index:99;overflow-x:auto}.tab{padding:8px 20px;border-radius:20px;border:none;font-size:15px;cursor:pointer;font-weight:500;white-space:nowrap;background:#e5e5ea;color:#3c3c43;transition:background .2s,color .2s}.tab.active{background:#007aff;color:#fff}.content{padding:8px 16px 100px}.category{margin-top:16px;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.06)}.category-header{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:#f9f9fb;border-bottom:1px solid #f2f2f7}.category-name{font-size:13px;font-weight:600;color:#6c6c70;letter-spacing:.3px}.add-btn{background:none;border:none;color:#007aff;font-size:14px;cursor:pointer;font-weight:500;padding:4px 0 4px 8px}.item-row{display:flex;align-items:center;padding:14px 16px;border-bottom:1px solid #f2f2f7;gap:12px;min-height:52px}.item-row:last-child{border-bottom:none}.checkbox{width:26px;height:26px;border-radius:50%;border:2px solid #c7c7cc;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s,border-color .15s}.checkbox.checked{background:#34c759;border-color:#34c759}.checkmark{display:none;color:#fff;font-size:14px;font-weight:700;line-height:1}.checkbox.checked .checkmark{display:block}.item-name{flex:1 1;font-size:17px;transition:color .2s}.item-name.checked{color:#c7c7cc;text-decoration:line-through}.delete-btn{background:none;border:none;color:#ff3b30;font-size:22px;cursor:pointer;padding:4px 4px 4px 8px;line-height:1;opacity:.5;flex-shrink:0;transition:opacity .2s}.delete-btn:hover{opacity:1}.add-form{display:flex;padding:10px 12px;gap:8px;border-top:1px solid #e5e5ea;background:#fafafa}.add-input{flex:1 1;padding:10px 12px;border:1.5px solid #007aff;border-radius:8px;font-size:16px;outline:none;background:#fff}.add-confirm-btn{padding:10px 16px;background:#007aff;color:#fff;border:none;border-radius:8px;font-size:15px;cursor:pointer;font-weight:500;white-space:nowrap}.add-cancel-btn{padding:10px 12px;background:none;color:#8e8e93;border:1px solid #c7c7cc;border-radius:8px;font-size:15px;cursor:pointer}.reset-section{margin-top:24px;text-align:center;padding-bottom:8px}.reset-btn{padding:13px 36px;background:#fff;border:1.5px solid #ff3b30;color:#ff3b30;border-radius:12px;font-size:16px;cursor:pointer;font-weight:500;box-shadow:0 1px 3px rgba(0,0,0,.06);transition:background .15s}.reset-btn:active{background:#fff5f5}.loading{display:flex;justify-content:center;align-items:center;height:60vh;font-size:17px;color:#8e8e93}