Okay I understand that this topic has been covered. But I have looked at various solutions and have had little success with them.
I just have no clue why this
You should set a width on .container to let the margin: 0 auto; work. See the updated JSfiddle.
.container
margin: 0 auto;