Consolidate button styles

This patchset will create consistent button styling according
to the styleguide and remove redundant button styles by creating
reusable button classes.

This patchset also implements a consistent strategy for including
icon assets. Currently, svg icons are imported as CSS background
images or inlined into the markup. Inlining an svg is preferred,
especially when used with buttons or links so the colors can
be easily changed for different states (hover, focus, disabled)
without having to request variants.
The icon provider allows us to inline svgs without cluttering
the markup. Webpack config was adjusted to use svg-inline-loader
when resolving svgs that are used by the icon provider directive.

- All svgs were optimized to remove unncessary information.
- Removed unused svg color variants
- Moved icons used by icon provider to separate directory to
  avoid Webpack parsing the files twice
- Small changes to navigation icons

Signed-off-by: Yoshie Muranaka <yoshiemuranaka@gmail.com>
Change-Id: I1ca214b74fc502e6b6e760cfee88b48110237c43
diff --git a/app/assets/icons/icon-copy.svg b/app/assets/icons/icon-copy.svg
new file mode 100644
index 0000000..a9b3be5
--- /dev/null
+++ b/app/assets/icons/icon-copy.svg
@@ -0,0 +1 @@
+<svg viewBox="0 0 32 32"><path d="M27.4346 14.6987L21.377 8.5776A1.9488 1.9488 0 0 0 19.998 8H12a2.002 2.002 0 0 0-2 2v19a2.002 2.002 0 0 0 2 2h14a2.002 2.002 0 0 0 2-2V16.0771a1.9755 1.9755 0 0 0-.5654-1.3784zM20 10.03L25.9235 16H20zM12 29V10h6v6a2.0023 2.0023 0 0 0 2 2h6.0006l.0009 11z"/><path d="M6 18H4V4a2.002 2.002 0 0 1 2-2h14v2H6z"/><path data-name="&lt;Transparent Rectangle&gt;" fill="none" d="M0 0h32v32H0z"/></svg>
\ No newline at end of file