Андрей: В целом вот ответ на ваш вопрос.
Несколько деталей:
1) .menu div - клик приходится на обертку картинки, а не на нее лично;
2) <div tabindex="0"> для того чтобы div мог работать с :focus ему необходимо задать этот параметр
Известный баг/явление с отступами у inline элементов. Побеждается несколькими способами. Например, float: left или отсуствием переноса строки в верстке:
Задайте расстояние между строками при помощи line-height. Или наоборот, убейте это расстояние в тексте , а div'ы позиционируйте уже как хотите и считайте как хотите.