In order to set up a foreign key relationship between two MySQL tables, three conditions must be met:
Both tables must be of the InnoDB table type.
The fields used in the foreign key relationship must be indexed.
The fields used in the foreign key relationship must be similar in data type.
I'm assuming you already use the InnoDB engine, and we can obviously see the data types are similar.
Try indexing the foreign key in the Orders table.
An afterthought occurs to me but I'd have to do more research to prove it... the table creation order may be significant.
All examples I've come across for creating tables with foreign keys create the referenced table first.
There is a brief but succinct tutorial on MySQL referential integrity
here.