Don't use style="display: none;" in SVG. You have it on the root element. Either visibility:hidden, height/width="0" or are better alternatives.
There used to be a bug in Firefox with gradient elements in symbols. That bug was fixed many versions ago now. The original code works as expected.