表題の通り
基本的には、"iOS safari 9.2 で window.innerWidth と viewport の値がズレる"で解決している内容です。
つまり、iOSでのviewportのサイズ参照はdocument.documentElement.clientWidth, document.documentElement.clientHeight使えというコトですが
私も含めブラウザのサイズ取得にはこれ(stackoverflow)
var w = Math.max(document.documentElement.clientWidth, window.innerWidth || 0);
var h = Math.max(document.documentElement.clientHeight, window.innerHeight || 0);```
をコピペしている方も多いのではないでしょうか。
このままだとmaxの判定でwindow.innerWidth, window.innerHeightが参照されてしまうというバグになります。
この現象は、iOS12.3以降、iPhone6で顕著に現れる様です。
iPhoneのスペック的にdocument.documentElement.client***が
viewportに基づいて更新される前に参照してしまうのが原因ではないかと思われます。
以上