Now running with the new Nginx setup.
I tried putting all the site configs in one file and using the $host variable to pick the right port (to proxy to) and certificates. Didn't work.
Instead, now I've split out the config into two include files, and a file for each domain/site. The per domain files just set the server name (per the Host: header), the proxy port, and the path to the certs, and then include the http include file (with the standard redirect) and the https include file (with all the other (mostly proxy) settings).
It's a shame that Nginx doesn't have a configuration level between http and server, to group config for similar sites, although using include is working for me here.
Last thought about this - I should be able to use the $server_name variable in the https include file to make the path to certs, so the only per site config is the server name and proxy port. (The point would be to minimise the chance that I'm going to forget to change a name when I next setup a site).
(Ok, I said last thought, but husband's site is static and can be handled by nginx on its own)