diff --git a/node_modules/material-design-lite/src/badge/README.md b/node_modules/material-design-lite/src/badge/README.md
new file mode 100644
index 0000000..abbc525
--- /dev/null
+++ b/node_modules/material-design-lite/src/badge/README.md
@@ -0,0 +1,68 @@
+## Introduction
+
+The Material Design Lite (MDL) **badge** component is an onscreen notification element. A badge consists of a small circle, typically containing a number or other characters, that appears in proximity to another object. A badge can be both a notifier that there are additional items associated with an object and an indicator of how many items there are.
+
+You can use a badge to unobtrusively draw the user's attention to items they might not otherwise notice, or to emphasize that items may need their attention. For example:
+
+* A "New messages" notification might be followed by a badge containing the number of unread messages.
+* A "You have unpurchased items in your shopping cart" reminder might include a badge showing the number of items in the cart.
+* A "Join the discussion!" button might have an accompanying badge indicating the number of users currently participating in the discussion.
+
+A badge is almost always positioned near a link so that the user has a convenient way to access the additional information indicated by the badge. However, depending on the intent, the badge itself may or may not be part of the link.
+
+Badges are a new feature in user interfaces, and provide users with a visual clue to help them discover additional relevant content. Their design and use is therefore an important factor in the overall user experience.
+
+### To include an MDL **badge** component:
+
+&nbsp;1. Code  an `<a>` (anchor/link) or a `<span>` element. Include any desired attributes and content.
+```html
+<a href="#">This link has a badge.</a>
+```
+&nbsp;2. Add one or more MDL classes, separated by spaces, to the element using the `class` attribute.
+```html
+<a href="#" class="mdl-badge">This link has a badge.</a>
+```
+&nbsp;3. Add a `data-badge` attribute and quoted string value for the badge.
+```html
+<a href="#" class="mdl-badge" data-badge="5">This link has a badge.</a>
+```
+
+The badge component is ready for use.
+
+>**Note:** Because of the badge component's small size, the `data-badge` value should typically contain one to three characters. More than three characters will not cause an error, but some characters may fall outside the badge and thus be difficult or impossible to see. The value of the `data-badge` attribute is centered in the badge.
+
+#### Examples
+
+A badge inside a link.
+```html
+<a href="#" class="mdl-badge" data-badge="7">This link contains a badge.</a>
+```
+
+A badge near, but not included in, a link.
+```html
+<a href="#">This link is followed by a badge.</a>
+<span class="mdl-badge" data-badge="12"></span>
+```
+
+A badge inside a link with too many characters to fit inside the badge.
+```html
+<a href="#" class="mdl-badge" data-badge="123456789">
+This badge has too many characters.</a>
+```
+
+A badge inside a link with no badge background color.
+```html
+<a href="#" class="mdl-badge mdl-badge--no-background" data-badge="123">
+This badge has no background color.</a>
+```
+
+## Configuration options
+
+The MDL CSS classes apply various predefined visual enhancements to the badge. The table below lists the available classes and their effects.
+
+| MDL class | Effect | Remarks |
+|-----------|--------|---------|
+| `mdl-badge` | Defines badge as an MDL component | Required on span or link |
+| `mdl-badge--no-background` | Applies open-circle effect to badge | Optional |
+| `mdl-badge--overlap` | Make the badge overlap with its container | Optional |
+| `data-badge="value"` | Assigns string value to badge | Not a class, but a separate attribute; required on span or link |
diff --git a/node_modules/material-design-lite/src/badge/_badge.scss b/node_modules/material-design-lite/src/badge/_badge.scss
new file mode 100644
index 0000000..c3b42ec
--- /dev/null
+++ b/node_modules/material-design-lite/src/badge/_badge.scss
@@ -0,0 +1,72 @@
+/**
+ * Copyright 2015 Google Inc. All Rights Reserved.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+@import "../variables";
+
+.mdl-badge {
+  position : relative;
+  white-space: nowrap;
+  margin-right: ($badge-size + $badge-padding);
+
+  &:not([data-badge]) {
+    margin-right: auto;
+  }
+
+  &[data-badge]:after {
+    content: attr(data-badge);
+
+    display: flex;
+    flex-direction: row;
+    flex-wrap: wrap;
+    justify-content: center;
+    align-content: center;
+    align-items: center;
+
+    position: absolute;
+    top: -($badge-size / 2);
+    right: -($badge-size + $badge-padding);
+
+    .mdl-button & {
+      top: -10px;
+      right: -5px;
+    }
+
+    font-family: $preferred_font;
+    font-weight: 600;
+    font-size: $badge-font-size;
+    width: $badge-size;
+    height: $badge-size;
+    border-radius : 50%;
+
+    background: $badge-background;
+    color: $badge-color;
+  }
+
+  &.mdl-badge--no-background {
+    &[data-badge]:after {
+      color: $badge-color-inverse;
+      background: $badge-background-inverse;
+
+      box-shadow: 0 0 1px gray;
+    }
+  }
+  &.mdl-badge--overlap {
+    margin-right: ($badge-size - $badge-overlap);
+    &:after {
+      right: -($badge-size - $badge-overlap);
+    }
+  }
+}
diff --git a/node_modules/material-design-lite/src/badge/snippets/badge-on-icon-icon-demo.html b/node_modules/material-design-lite/src/badge/snippets/badge-on-icon-icon-demo.html
new file mode 100644
index 0000000..1baa6ff
--- /dev/null
+++ b/node_modules/material-design-lite/src/badge/snippets/badge-on-icon-icon-demo.html
@@ -0,0 +1,9 @@
+<style>
+.demo-badge__badge-on-icon-icon .mdl-badge {
+  color: rgba(0, 0, 0, 0.24);
+}
+.demo-badge__badge-on-icon-icon .mdl-badge.material-icons {
+  font-size: 32px;
+}
+</style>
+{% include "badge-on-icon-icon.html" %}
diff --git a/node_modules/material-design-lite/src/badge/snippets/badge-on-icon-icon.html b/node_modules/material-design-lite/src/badge/snippets/badge-on-icon-icon.html
new file mode 100644
index 0000000..3b23967
--- /dev/null
+++ b/node_modules/material-design-lite/src/badge/snippets/badge-on-icon-icon.html
@@ -0,0 +1,2 @@
+<!-- Icon badge on icon -->
+<div class="material-icons mdl-badge mdl-badge--overlap" data-badge="♥">account_box</div>
diff --git a/node_modules/material-design-lite/src/badge/snippets/badge-on-icon-text-demo.html b/node_modules/material-design-lite/src/badge/snippets/badge-on-icon-text-demo.html
new file mode 100644
index 0000000..1437ef8
--- /dev/null
+++ b/node_modules/material-design-lite/src/badge/snippets/badge-on-icon-text-demo.html
@@ -0,0 +1,9 @@
+<style>
+.demo-badge__badge-on-icon-text .mdl-badge {
+  color: rgba(0, 0, 0, 0.24);
+}
+.demo-badge__badge-on-icon-text .mdl-badge.material-icons {
+  font-size: 32px;
+}
+</style>
+{% include "badge-on-icon-text.html" %}
diff --git a/node_modules/material-design-lite/src/badge/snippets/badge-on-icon-text.html b/node_modules/material-design-lite/src/badge/snippets/badge-on-icon-text.html
new file mode 100644
index 0000000..e73a9f2
--- /dev/null
+++ b/node_modules/material-design-lite/src/badge/snippets/badge-on-icon-text.html
@@ -0,0 +1,2 @@
+<!-- Number badge on icon -->
+<div class="material-icons mdl-badge mdl-badge--overlap" data-badge="1">account_box</div>
diff --git a/node_modules/material-design-lite/src/badge/snippets/badge-on-text-icon-demo.html b/node_modules/material-design-lite/src/badge/snippets/badge-on-text-icon-demo.html
new file mode 100644
index 0000000..57ab2bf
--- /dev/null
+++ b/node_modules/material-design-lite/src/badge/snippets/badge-on-text-icon-demo.html
@@ -0,0 +1,6 @@
+<style>
+.demo-badge__badge-on-text-icon .mdl-badge {
+  color: rgba(0, 0, 0, 0.24);
+}
+</style>
+{% include "badge-on-text-icon.html" %}
diff --git a/node_modules/material-design-lite/src/badge/snippets/badge-on-text-icon.html b/node_modules/material-design-lite/src/badge/snippets/badge-on-text-icon.html
new file mode 100644
index 0000000..86c1240
--- /dev/null
+++ b/node_modules/material-design-lite/src/badge/snippets/badge-on-text-icon.html
@@ -0,0 +1,2 @@
+<!-- Icon badge -->
+<span class="mdl-badge" data-badge="♥">Mood</span>
diff --git a/node_modules/material-design-lite/src/badge/snippets/badge-on-text-text-demo.html b/node_modules/material-design-lite/src/badge/snippets/badge-on-text-text-demo.html
new file mode 100644
index 0000000..37d26e1
--- /dev/null
+++ b/node_modules/material-design-lite/src/badge/snippets/badge-on-text-text-demo.html
@@ -0,0 +1,7 @@
+<style>
+.demo-badge__badge-on-text-text .mdl-badge {
+  color: rgba(0, 0, 0, 0.24);
+}
+</style>
+
+{% include "badge-on-text-text.html" %}
diff --git a/node_modules/material-design-lite/src/badge/snippets/badge-on-text-text.html b/node_modules/material-design-lite/src/badge/snippets/badge-on-text-text.html
new file mode 100644
index 0000000..d2f66eb
--- /dev/null
+++ b/node_modules/material-design-lite/src/badge/snippets/badge-on-text-text.html
@@ -0,0 +1,2 @@
+<!-- Number badge -->
+<span class="mdl-badge" data-badge="4">Inbox</span>
