Instead of using the time zone 'UTC-7' it's using 'UTC+7', which is 14 hours different.
It depends whether +/- means east or west of GreenwhichGreenwich, and it turns out both conventions exist. PostgreSQL doc warns about that:
http://www.postgresql.org/docs/current/static/datatype-datetime.html
Excerpt from 8.5.3. Time Zones (but you really want to read the whole paragraph):
Another issue to keep in mind is that in POSIX time zone names, positive offsets are used for locations west of Greenwich. Everywhere else, PostgreSQL follows the ISO-8601 convention that positive timezone offsets are east of Greenwich.
Using ISO 8601 time zone notation also yields the opposite from the expected result:
In the same page, the accepted formats for time zone literals are listed, here's a condensed version:
PostgreSQL allows you to specify time zones in three different forms:
A full time zone name, for example America/New_York [...]
A time zone abbreviation, for example PST[...]
In addition to the timezone names and abbreviations, PostgreSQL will accept POSIX-style time zone specifications of the form STDoffset or STDoffsetDST, where STD is a zone abbreviation, offset is a numeric offset in hours west from UTC, and DST is an optional daylight-savings zone abbreviation,[...]
Note that it never pretends to accept an ISO 8601 time zone designator. And as you found out with -0700, it doesn't. You should just use one of the forms above.
Also beware of (false) conclusions that because the parser doesn't reject a time zone, it's valid:
One should be wary that the POSIX-style time zone feature can lead to silently accepting bogus input, since there is no check on the reasonableness of the zone abbreviations