немного в другую сторону, но как вариант все же - mobiledetect.net
библиотека на php. определяете браузер и выставляете нужные классы.
А с сафари вообще беда. Даже ослик на него смотрит как на сами знаете что.
не пробовал, но может сработать: тут смотрите первый пример,
делаете градиент для блока и конечный цвет этого градиента делаете начальным градиентом для треугольника.
Ну а треугольник как сделать с помощью границ - инфы полно.