From f82aa4c734dc022a84c9e769f688d2647f8716e4 Mon Sep 17 00:00:00 2001
From: adrien <adrien@malingrey.fr>
Date: Sun, 26 Sep 2021 01:43:44 +0200
Subject: [PATCH] Materialized

---
 css/icons.css                            |    23 +
 css/materialize.css                      |  9085 +++++++++++++++
 css/style.css                            |    10 +
 fonts/flUhRq6tzZclQEJ-Vdg-IuiaDsNc.woff2 |   Bin 0 -> 110560 bytes
 nok.png => img/nok.png                   |   Bin
 ok.png => img/ok.png                     |   Bin
 wait.gif => img/wait.gif                 |   Bin
 index.php                                |    16 +-
 js/materialize.js                        | 12374 +++++++++++++++++++++
 script.js => js/script.js                |     4 +-
 siteNetworks.php                         |   139 +-
 sitesList.php                            |    48 +-
 style.css                                |    45 -
 13 files changed, 21611 insertions(+), 133 deletions(-)
 create mode 100644 css/icons.css
 create mode 100644 css/materialize.css
 create mode 100644 css/style.css
 create mode 100644 fonts/flUhRq6tzZclQEJ-Vdg-IuiaDsNc.woff2
 rename nok.png => img/nok.png (100%)
 rename ok.png => img/ok.png (100%)
 rename wait.gif => img/wait.gif (100%)
 create mode 100644 js/materialize.js
 rename script.js => js/script.js (81%)
 delete mode 100644 style.css

diff --git a/css/icons.css b/css/icons.css
new file mode 100644
index 0000000..5725228
--- /dev/null
+++ b/css/icons.css
@@ -0,0 +1,23 @@
+/* fallback */
+@font-face {
+  font-family: 'Material Icons';
+  font-style: normal;
+  font-weight: 400;
+  src: url(../fonts/flUhRq6tzZclQEJ-Vdg-IuiaDsNc.woff2) format('woff2');
+}
+
+.material-icons {
+  font-family: 'Material Icons';
+  font-weight: normal;
+  font-style: normal;
+  font-size: 24px;
+  line-height: 1;
+  letter-spacing: normal;
+  text-transform: none;
+  display: inline-block;
+  white-space: nowrap;
+  word-wrap: normal;
+  direction: ltr;
+  -moz-font-feature-settings: 'liga';
+  -moz-osx-font-smoothing: grayscale;
+}
diff --git a/css/materialize.css b/css/materialize.css
new file mode 100644
index 0000000..68bb261
--- /dev/null
+++ b/css/materialize.css
@@ -0,0 +1,9085 @@
+/*!
+ * Materialize v1.0.0 (http://materializecss.com)
+ * Copyright 2014-2017 Materialize
+ * MIT License (https://raw.githubusercontent.com/Dogfalo/materialize/master/LICENSE)
+ */
+.materialize-red {
+  background-color: #e51c23 !important;
+}
+
+.materialize-red-text {
+  color: #e51c23 !important;
+}
+
+.materialize-red.lighten-5 {
+  background-color: #fdeaeb !important;
+}
+
+.materialize-red-text.text-lighten-5 {
+  color: #fdeaeb !important;
+}
+
+.materialize-red.lighten-4 {
+  background-color: #f8c1c3 !important;
+}
+
+.materialize-red-text.text-lighten-4 {
+  color: #f8c1c3 !important;
+}
+
+.materialize-red.lighten-3 {
+  background-color: #f3989b !important;
+}
+
+.materialize-red-text.text-lighten-3 {
+  color: #f3989b !important;
+}
+
+.materialize-red.lighten-2 {
+  background-color: #ee6e73 !important;
+}
+
+.materialize-red-text.text-lighten-2 {
+  color: #ee6e73 !important;
+}
+
+.materialize-red.lighten-1 {
+  background-color: #ea454b !important;
+}
+
+.materialize-red-text.text-lighten-1 {
+  color: #ea454b !important;
+}
+
+.materialize-red.darken-1 {
+  background-color: #d0181e !important;
+}
+
+.materialize-red-text.text-darken-1 {
+  color: #d0181e !important;
+}
+
+.materialize-red.darken-2 {
+  background-color: #b9151b !important;
+}
+
+.materialize-red-text.text-darken-2 {
+  color: #b9151b !important;
+}
+
+.materialize-red.darken-3 {
+  background-color: #a21318 !important;
+}
+
+.materialize-red-text.text-darken-3 {
+  color: #a21318 !important;
+}
+
+.materialize-red.darken-4 {
+  background-color: #8b1014 !important;
+}
+
+.materialize-red-text.text-darken-4 {
+  color: #8b1014 !important;
+}
+
+.red {
+  background-color: #F44336 !important;
+}
+
+.red-text {
+  color: #F44336 !important;
+}
+
+.red.lighten-5 {
+  background-color: #FFEBEE !important;
+}
+
+.red-text.text-lighten-5 {
+  color: #FFEBEE !important;
+}
+
+.red.lighten-4 {
+  background-color: #FFCDD2 !important;
+}
+
+.red-text.text-lighten-4 {
+  color: #FFCDD2 !important;
+}
+
+.red.lighten-3 {
+  background-color: #EF9A9A !important;
+}
+
+.red-text.text-lighten-3 {
+  color: #EF9A9A !important;
+}
+
+.red.lighten-2 {
+  background-color: #E57373 !important;
+}
+
+.red-text.text-lighten-2 {
+  color: #E57373 !important;
+}
+
+.red.lighten-1 {
+  background-color: #EF5350 !important;
+}
+
+.red-text.text-lighten-1 {
+  color: #EF5350 !important;
+}
+
+.red.darken-1 {
+  background-color: #E53935 !important;
+}
+
+.red-text.text-darken-1 {
+  color: #E53935 !important;
+}
+
+.red.darken-2 {
+  background-color: #D32F2F !important;
+}
+
+.red-text.text-darken-2 {
+  color: #D32F2F !important;
+}
+
+.red.darken-3 {
+  background-color: #C62828 !important;
+}
+
+.red-text.text-darken-3 {
+  color: #C62828 !important;
+}
+
+.red.darken-4 {
+  background-color: #B71C1C !important;
+}
+
+.red-text.text-darken-4 {
+  color: #B71C1C !important;
+}
+
+.red.accent-1 {
+  background-color: #FF8A80 !important;
+}
+
+.red-text.text-accent-1 {
+  color: #FF8A80 !important;
+}
+
+.red.accent-2 {
+  background-color: #FF5252 !important;
+}
+
+.red-text.text-accent-2 {
+  color: #FF5252 !important;
+}
+
+.red.accent-3 {
+  background-color: #FF1744 !important;
+}
+
+.red-text.text-accent-3 {
+  color: #FF1744 !important;
+}
+
+.red.accent-4 {
+  background-color: #D50000 !important;
+}
+
+.red-text.text-accent-4 {
+  color: #D50000 !important;
+}
+
+.pink {
+  background-color: #e91e63 !important;
+}
+
+.pink-text {
+  color: #e91e63 !important;
+}
+
+.pink.lighten-5 {
+  background-color: #fce4ec !important;
+}
+
+.pink-text.text-lighten-5 {
+  color: #fce4ec !important;
+}
+
+.pink.lighten-4 {
+  background-color: #f8bbd0 !important;
+}
+
+.pink-text.text-lighten-4 {
+  color: #f8bbd0 !important;
+}
+
+.pink.lighten-3 {
+  background-color: #f48fb1 !important;
+}
+
+.pink-text.text-lighten-3 {
+  color: #f48fb1 !important;
+}
+
+.pink.lighten-2 {
+  background-color: #f06292 !important;
+}
+
+.pink-text.text-lighten-2 {
+  color: #f06292 !important;
+}
+
+.pink.lighten-1 {
+  background-color: #ec407a !important;
+}
+
+.pink-text.text-lighten-1 {
+  color: #ec407a !important;
+}
+
+.pink.darken-1 {
+  background-color: #d81b60 !important;
+}
+
+.pink-text.text-darken-1 {
+  color: #d81b60 !important;
+}
+
+.pink.darken-2 {
+  background-color: #c2185b !important;
+}
+
+.pink-text.text-darken-2 {
+  color: #c2185b !important;
+}
+
+.pink.darken-3 {
+  background-color: #ad1457 !important;
+}
+
+.pink-text.text-darken-3 {
+  color: #ad1457 !important;
+}
+
+.pink.darken-4 {
+  background-color: #880e4f !important;
+}
+
+.pink-text.text-darken-4 {
+  color: #880e4f !important;
+}
+
+.pink.accent-1 {
+  background-color: #ff80ab !important;
+}
+
+.pink-text.text-accent-1 {
+  color: #ff80ab !important;
+}
+
+.pink.accent-2 {
+  background-color: #ff4081 !important;
+}
+
+.pink-text.text-accent-2 {
+  color: #ff4081 !important;
+}
+
+.pink.accent-3 {
+  background-color: #f50057 !important;
+}
+
+.pink-text.text-accent-3 {
+  color: #f50057 !important;
+}
+
+.pink.accent-4 {
+  background-color: #c51162 !important;
+}
+
+.pink-text.text-accent-4 {
+  color: #c51162 !important;
+}
+
+.purple {
+  background-color: #9c27b0 !important;
+}
+
+.purple-text {
+  color: #9c27b0 !important;
+}
+
+.purple.lighten-5 {
+  background-color: #f3e5f5 !important;
+}
+
+.purple-text.text-lighten-5 {
+  color: #f3e5f5 !important;
+}
+
+.purple.lighten-4 {
+  background-color: #e1bee7 !important;
+}
+
+.purple-text.text-lighten-4 {
+  color: #e1bee7 !important;
+}
+
+.purple.lighten-3 {
+  background-color: #ce93d8 !important;
+}
+
+.purple-text.text-lighten-3 {
+  color: #ce93d8 !important;
+}
+
+.purple.lighten-2 {
+  background-color: #ba68c8 !important;
+}
+
+.purple-text.text-lighten-2 {
+  color: #ba68c8 !important;
+}
+
+.purple.lighten-1 {
+  background-color: #ab47bc !important;
+}
+
+.purple-text.text-lighten-1 {
+  color: #ab47bc !important;
+}
+
+.purple.darken-1 {
+  background-color: #8e24aa !important;
+}
+
+.purple-text.text-darken-1 {
+  color: #8e24aa !important;
+}
+
+.purple.darken-2 {
+  background-color: #7b1fa2 !important;
+}
+
+.purple-text.text-darken-2 {
+  color: #7b1fa2 !important;
+}
+
+.purple.darken-3 {
+  background-color: #6a1b9a !important;
+}
+
+.purple-text.text-darken-3 {
+  color: #6a1b9a !important;
+}
+
+.purple.darken-4 {
+  background-color: #4a148c !important;
+}
+
+.purple-text.text-darken-4 {
+  color: #4a148c !important;
+}
+
+.purple.accent-1 {
+  background-color: #ea80fc !important;
+}
+
+.purple-text.text-accent-1 {
+  color: #ea80fc !important;
+}
+
+.purple.accent-2 {
+  background-color: #e040fb !important;
+}
+
+.purple-text.text-accent-2 {
+  color: #e040fb !important;
+}
+
+.purple.accent-3 {
+  background-color: #d500f9 !important;
+}
+
+.purple-text.text-accent-3 {
+  color: #d500f9 !important;
+}
+
+.purple.accent-4 {
+  background-color: #aa00ff !important;
+}
+
+.purple-text.text-accent-4 {
+  color: #aa00ff !important;
+}
+
+.deep-purple {
+  background-color: #673ab7 !important;
+}
+
+.deep-purple-text {
+  color: #673ab7 !important;
+}
+
+.deep-purple.lighten-5 {
+  background-color: #ede7f6 !important;
+}
+
+.deep-purple-text.text-lighten-5 {
+  color: #ede7f6 !important;
+}
+
+.deep-purple.lighten-4 {
+  background-color: #d1c4e9 !important;
+}
+
+.deep-purple-text.text-lighten-4 {
+  color: #d1c4e9 !important;
+}
+
+.deep-purple.lighten-3 {
+  background-color: #b39ddb !important;
+}
+
+.deep-purple-text.text-lighten-3 {
+  color: #b39ddb !important;
+}
+
+.deep-purple.lighten-2 {
+  background-color: #9575cd !important;
+}
+
+.deep-purple-text.text-lighten-2 {
+  color: #9575cd !important;
+}
+
+.deep-purple.lighten-1 {
+  background-color: #7e57c2 !important;
+}
+
+.deep-purple-text.text-lighten-1 {
+  color: #7e57c2 !important;
+}
+
+.deep-purple.darken-1 {
+  background-color: #5e35b1 !important;
+}
+
+.deep-purple-text.text-darken-1 {
+  color: #5e35b1 !important;
+}
+
+.deep-purple.darken-2 {
+  background-color: #512da8 !important;
+}
+
+.deep-purple-text.text-darken-2 {
+  color: #512da8 !important;
+}
+
+.deep-purple.darken-3 {
+  background-color: #4527a0 !important;
+}
+
+.deep-purple-text.text-darken-3 {
+  color: #4527a0 !important;
+}
+
+.deep-purple.darken-4 {
+  background-color: #311b92 !important;
+}
+
+.deep-purple-text.text-darken-4 {
+  color: #311b92 !important;
+}
+
+.deep-purple.accent-1 {
+  background-color: #b388ff !important;
+}
+
+.deep-purple-text.text-accent-1 {
+  color: #b388ff !important;
+}
+
+.deep-purple.accent-2 {
+  background-color: #7c4dff !important;
+}
+
+.deep-purple-text.text-accent-2 {
+  color: #7c4dff !important;
+}
+
+.deep-purple.accent-3 {
+  background-color: #651fff !important;
+}
+
+.deep-purple-text.text-accent-3 {
+  color: #651fff !important;
+}
+
+.deep-purple.accent-4 {
+  background-color: #6200ea !important;
+}
+
+.deep-purple-text.text-accent-4 {
+  color: #6200ea !important;
+}
+
+.indigo {
+  background-color: #3f51b5 !important;
+}
+
+.indigo-text {
+  color: #3f51b5 !important;
+}
+
+.indigo.lighten-5 {
+  background-color: #e8eaf6 !important;
+}
+
+.indigo-text.text-lighten-5 {
+  color: #e8eaf6 !important;
+}
+
+.indigo.lighten-4 {
+  background-color: #c5cae9 !important;
+}
+
+.indigo-text.text-lighten-4 {
+  color: #c5cae9 !important;
+}
+
+.indigo.lighten-3 {
+  background-color: #9fa8da !important;
+}
+
+.indigo-text.text-lighten-3 {
+  color: #9fa8da !important;
+}
+
+.indigo.lighten-2 {
+  background-color: #7986cb !important;
+}
+
+.indigo-text.text-lighten-2 {
+  color: #7986cb !important;
+}
+
+.indigo.lighten-1 {
+  background-color: #5c6bc0 !important;
+}
+
+.indigo-text.text-lighten-1 {
+  color: #5c6bc0 !important;
+}
+
+.indigo.darken-1 {
+  background-color: #3949ab !important;
+}
+
+.indigo-text.text-darken-1 {
+  color: #3949ab !important;
+}
+
+.indigo.darken-2 {
+  background-color: #303f9f !important;
+}
+
+.indigo-text.text-darken-2 {
+  color: #303f9f !important;
+}
+
+.indigo.darken-3 {
+  background-color: #283593 !important;
+}
+
+.indigo-text.text-darken-3 {
+  color: #283593 !important;
+}
+
+.indigo.darken-4 {
+  background-color: #1a237e !important;
+}
+
+.indigo-text.text-darken-4 {
+  color: #1a237e !important;
+}
+
+.indigo.accent-1 {
+  background-color: #8c9eff !important;
+}
+
+.indigo-text.text-accent-1 {
+  color: #8c9eff !important;
+}
+
+.indigo.accent-2 {
+  background-color: #536dfe !important;
+}
+
+.indigo-text.text-accent-2 {
+  color: #536dfe !important;
+}
+
+.indigo.accent-3 {
+  background-color: #3d5afe !important;
+}
+
+.indigo-text.text-accent-3 {
+  color: #3d5afe !important;
+}
+
+.indigo.accent-4 {
+  background-color: #304ffe !important;
+}
+
+.indigo-text.text-accent-4 {
+  color: #304ffe !important;
+}
+
+.blue {
+  background-color: #2196F3 !important;
+}
+
+.blue-text {
+  color: #2196F3 !important;
+}
+
+.blue.lighten-5 {
+  background-color: #E3F2FD !important;
+}
+
+.blue-text.text-lighten-5 {
+  color: #E3F2FD !important;
+}
+
+.blue.lighten-4 {
+  background-color: #BBDEFB !important;
+}
+
+.blue-text.text-lighten-4 {
+  color: #BBDEFB !important;
+}
+
+.blue.lighten-3 {
+  background-color: #90CAF9 !important;
+}
+
+.blue-text.text-lighten-3 {
+  color: #90CAF9 !important;
+}
+
+.blue.lighten-2 {
+  background-color: #64B5F6 !important;
+}
+
+.blue-text.text-lighten-2 {
+  color: #64B5F6 !important;
+}
+
+.blue.lighten-1 {
+  background-color: #42A5F5 !important;
+}
+
+.blue-text.text-lighten-1 {
+  color: #42A5F5 !important;
+}
+
+.blue.darken-1 {
+  background-color: #1E88E5 !important;
+}
+
+.blue-text.text-darken-1 {
+  color: #1E88E5 !important;
+}
+
+.blue.darken-2 {
+  background-color: #1976D2 !important;
+}
+
+.blue-text.text-darken-2 {
+  color: #1976D2 !important;
+}
+
+.blue.darken-3 {
+  background-color: #1565C0 !important;
+}
+
+.blue-text.text-darken-3 {
+  color: #1565C0 !important;
+}
+
+.blue.darken-4 {
+  background-color: #0D47A1 !important;
+}
+
+.blue-text.text-darken-4 {
+  color: #0D47A1 !important;
+}
+
+.blue.accent-1 {
+  background-color: #82B1FF !important;
+}
+
+.blue-text.text-accent-1 {
+  color: #82B1FF !important;
+}
+
+.blue.accent-2 {
+  background-color: #448AFF !important;
+}
+
+.blue-text.text-accent-2 {
+  color: #448AFF !important;
+}
+
+.blue.accent-3 {
+  background-color: #2979FF !important;
+}
+
+.blue-text.text-accent-3 {
+  color: #2979FF !important;
+}
+
+.blue.accent-4 {
+  background-color: #2962FF !important;
+}
+
+.blue-text.text-accent-4 {
+  color: #2962FF !important;
+}
+
+.light-blue {
+  background-color: #03a9f4 !important;
+}
+
+.light-blue-text {
+  color: #03a9f4 !important;
+}
+
+.light-blue.lighten-5 {
+  background-color: #e1f5fe !important;
+}
+
+.light-blue-text.text-lighten-5 {
+  color: #e1f5fe !important;
+}
+
+.light-blue.lighten-4 {
+  background-color: #b3e5fc !important;
+}
+
+.light-blue-text.text-lighten-4 {
+  color: #b3e5fc !important;
+}
+
+.light-blue.lighten-3 {
+  background-color: #81d4fa !important;
+}
+
+.light-blue-text.text-lighten-3 {
+  color: #81d4fa !important;
+}
+
+.light-blue.lighten-2 {
+  background-color: #4fc3f7 !important;
+}
+
+.light-blue-text.text-lighten-2 {
+  color: #4fc3f7 !important;
+}
+
+.light-blue.lighten-1 {
+  background-color: #29b6f6 !important;
+}
+
+.light-blue-text.text-lighten-1 {
+  color: #29b6f6 !important;
+}
+
+.light-blue.darken-1 {
+  background-color: #039be5 !important;
+}
+
+.light-blue-text.text-darken-1 {
+  color: #039be5 !important;
+}
+
+.light-blue.darken-2 {
+  background-color: #0288d1 !important;
+}
+
+.light-blue-text.text-darken-2 {
+  color: #0288d1 !important;
+}
+
+.light-blue.darken-3 {
+  background-color: #0277bd !important;
+}
+
+.light-blue-text.text-darken-3 {
+  color: #0277bd !important;
+}
+
+.light-blue.darken-4 {
+  background-color: #01579b !important;
+}
+
+.light-blue-text.text-darken-4 {
+  color: #01579b !important;
+}
+
+.light-blue.accent-1 {
+  background-color: #80d8ff !important;
+}
+
+.light-blue-text.text-accent-1 {
+  color: #80d8ff !important;
+}
+
+.light-blue.accent-2 {
+  background-color: #40c4ff !important;
+}
+
+.light-blue-text.text-accent-2 {
+  color: #40c4ff !important;
+}
+
+.light-blue.accent-3 {
+  background-color: #00b0ff !important;
+}
+
+.light-blue-text.text-accent-3 {
+  color: #00b0ff !important;
+}
+
+.light-blue.accent-4 {
+  background-color: #0091ea !important;
+}
+
+.light-blue-text.text-accent-4 {
+  color: #0091ea !important;
+}
+
+.cyan {
+  background-color: #00bcd4 !important;
+}
+
+.cyan-text {
+  color: #00bcd4 !important;
+}
+
+.cyan.lighten-5 {
+  background-color: #e0f7fa !important;
+}
+
+.cyan-text.text-lighten-5 {
+  color: #e0f7fa !important;
+}
+
+.cyan.lighten-4 {
+  background-color: #b2ebf2 !important;
+}
+
+.cyan-text.text-lighten-4 {
+  color: #b2ebf2 !important;
+}
+
+.cyan.lighten-3 {
+  background-color: #80deea !important;
+}
+
+.cyan-text.text-lighten-3 {
+  color: #80deea !important;
+}
+
+.cyan.lighten-2 {
+  background-color: #4dd0e1 !important;
+}
+
+.cyan-text.text-lighten-2 {
+  color: #4dd0e1 !important;
+}
+
+.cyan.lighten-1 {
+  background-color: #26c6da !important;
+}
+
+.cyan-text.text-lighten-1 {
+  color: #26c6da !important;
+}
+
+.cyan.darken-1 {
+  background-color: #00acc1 !important;
+}
+
+.cyan-text.text-darken-1 {
+  color: #00acc1 !important;
+}
+
+.cyan.darken-2 {
+  background-color: #0097a7 !important;
+}
+
+.cyan-text.text-darken-2 {
+  color: #0097a7 !important;
+}
+
+.cyan.darken-3 {
+  background-color: #00838f !important;
+}
+
+.cyan-text.text-darken-3 {
+  color: #00838f !important;
+}
+
+.cyan.darken-4 {
+  background-color: #006064 !important;
+}
+
+.cyan-text.text-darken-4 {
+  color: #006064 !important;
+}
+
+.cyan.accent-1 {
+  background-color: #84ffff !important;
+}
+
+.cyan-text.text-accent-1 {
+  color: #84ffff !important;
+}
+
+.cyan.accent-2 {
+  background-color: #18ffff !important;
+}
+
+.cyan-text.text-accent-2 {
+  color: #18ffff !important;
+}
+
+.cyan.accent-3 {
+  background-color: #00e5ff !important;
+}
+
+.cyan-text.text-accent-3 {
+  color: #00e5ff !important;
+}
+
+.cyan.accent-4 {
+  background-color: #00b8d4 !important;
+}
+
+.cyan-text.text-accent-4 {
+  color: #00b8d4 !important;
+}
+
+.teal {
+  background-color: #009688 !important;
+}
+
+.teal-text {
+  color: #009688 !important;
+}
+
+.teal.lighten-5 {
+  background-color: #e0f2f1 !important;
+}
+
+.teal-text.text-lighten-5 {
+  color: #e0f2f1 !important;
+}
+
+.teal.lighten-4 {
+  background-color: #b2dfdb !important;
+}
+
+.teal-text.text-lighten-4 {
+  color: #b2dfdb !important;
+}
+
+.teal.lighten-3 {
+  background-color: #80cbc4 !important;
+}
+
+.teal-text.text-lighten-3 {
+  color: #80cbc4 !important;
+}
+
+.teal.lighten-2 {
+  background-color: #4db6ac !important;
+}
+
+.teal-text.text-lighten-2 {
+  color: #4db6ac !important;
+}
+
+.teal.lighten-1 {
+  background-color: #26a69a !important;
+}
+
+.teal-text.text-lighten-1 {
+  color: #26a69a !important;
+}
+
+.teal.darken-1 {
+  background-color: #00897b !important;
+}
+
+.teal-text.text-darken-1 {
+  color: #00897b !important;
+}
+
+.teal.darken-2 {
+  background-color: #00796b !important;
+}
+
+.teal-text.text-darken-2 {
+  color: #00796b !important;
+}
+
+.teal.darken-3 {
+  background-color: #00695c !important;
+}
+
+.teal-text.text-darken-3 {
+  color: #00695c !important;
+}
+
+.teal.darken-4 {
+  background-color: #004d40 !important;
+}
+
+.teal-text.text-darken-4 {
+  color: #004d40 !important;
+}
+
+.teal.accent-1 {
+  background-color: #a7ffeb !important;
+}
+
+.teal-text.text-accent-1 {
+  color: #a7ffeb !important;
+}
+
+.teal.accent-2 {
+  background-color: #64ffda !important;
+}
+
+.teal-text.text-accent-2 {
+  color: #64ffda !important;
+}
+
+.teal.accent-3 {
+  background-color: #1de9b6 !important;
+}
+
+.teal-text.text-accent-3 {
+  color: #1de9b6 !important;
+}
+
+.teal.accent-4 {
+  background-color: #00bfa5 !important;
+}
+
+.teal-text.text-accent-4 {
+  color: #00bfa5 !important;
+}
+
+.green {
+  background-color: #4CAF50 !important;
+}
+
+.green-text {
+  color: #4CAF50 !important;
+}
+
+.green.lighten-5 {
+  background-color: #E8F5E9 !important;
+}
+
+.green-text.text-lighten-5 {
+  color: #E8F5E9 !important;
+}
+
+.green.lighten-4 {
+  background-color: #C8E6C9 !important;
+}
+
+.green-text.text-lighten-4 {
+  color: #C8E6C9 !important;
+}
+
+.green.lighten-3 {
+  background-color: #A5D6A7 !important;
+}
+
+.green-text.text-lighten-3 {
+  color: #A5D6A7 !important;
+}
+
+.green.lighten-2 {
+  background-color: #81C784 !important;
+}
+
+.green-text.text-lighten-2 {
+  color: #81C784 !important;
+}
+
+.green.lighten-1 {
+  background-color: #66BB6A !important;
+}
+
+.green-text.text-lighten-1 {
+  color: #66BB6A !important;
+}
+
+.green.darken-1 {
+  background-color: #43A047 !important;
+}
+
+.green-text.text-darken-1 {
+  color: #43A047 !important;
+}
+
+.green.darken-2 {
+  background-color: #388E3C !important;
+}
+
+.green-text.text-darken-2 {
+  color: #388E3C !important;
+}
+
+.green.darken-3 {
+  background-color: #2E7D32 !important;
+}
+
+.green-text.text-darken-3 {
+  color: #2E7D32 !important;
+}
+
+.green.darken-4 {
+  background-color: #1B5E20 !important;
+}
+
+.green-text.text-darken-4 {
+  color: #1B5E20 !important;
+}
+
+.green.accent-1 {
+  background-color: #B9F6CA !important;
+}
+
+.green-text.text-accent-1 {
+  color: #B9F6CA !important;
+}
+
+.green.accent-2 {
+  background-color: #69F0AE !important;
+}
+
+.green-text.text-accent-2 {
+  color: #69F0AE !important;
+}
+
+.green.accent-3 {
+  background-color: #00E676 !important;
+}
+
+.green-text.text-accent-3 {
+  color: #00E676 !important;
+}
+
+.green.accent-4 {
+  background-color: #00C853 !important;
+}
+
+.green-text.text-accent-4 {
+  color: #00C853 !important;
+}
+
+.light-green {
+  background-color: #8bc34a !important;
+}
+
+.light-green-text {
+  color: #8bc34a !important;
+}
+
+.light-green.lighten-5 {
+  background-color: #f1f8e9 !important;
+}
+
+.light-green-text.text-lighten-5 {
+  color: #f1f8e9 !important;
+}
+
+.light-green.lighten-4 {
+  background-color: #dcedc8 !important;
+}
+
+.light-green-text.text-lighten-4 {
+  color: #dcedc8 !important;
+}
+
+.light-green.lighten-3 {
+  background-color: #c5e1a5 !important;
+}
+
+.light-green-text.text-lighten-3 {
+  color: #c5e1a5 !important;
+}
+
+.light-green.lighten-2 {
+  background-color: #aed581 !important;
+}
+
+.light-green-text.text-lighten-2 {
+  color: #aed581 !important;
+}
+
+.light-green.lighten-1 {
+  background-color: #9ccc65 !important;
+}
+
+.light-green-text.text-lighten-1 {
+  color: #9ccc65 !important;
+}
+
+.light-green.darken-1 {
+  background-color: #7cb342 !important;
+}
+
+.light-green-text.text-darken-1 {
+  color: #7cb342 !important;
+}
+
+.light-green.darken-2 {
+  background-color: #689f38 !important;
+}
+
+.light-green-text.text-darken-2 {
+  color: #689f38 !important;
+}
+
+.light-green.darken-3 {
+  background-color: #558b2f !important;
+}
+
+.light-green-text.text-darken-3 {
+  color: #558b2f !important;
+}
+
+.light-green.darken-4 {
+  background-color: #33691e !important;
+}
+
+.light-green-text.text-darken-4 {
+  color: #33691e !important;
+}
+
+.light-green.accent-1 {
+  background-color: #ccff90 !important;
+}
+
+.light-green-text.text-accent-1 {
+  color: #ccff90 !important;
+}
+
+.light-green.accent-2 {
+  background-color: #b2ff59 !important;
+}
+
+.light-green-text.text-accent-2 {
+  color: #b2ff59 !important;
+}
+
+.light-green.accent-3 {
+  background-color: #76ff03 !important;
+}
+
+.light-green-text.text-accent-3 {
+  color: #76ff03 !important;
+}
+
+.light-green.accent-4 {
+  background-color: #64dd17 !important;
+}
+
+.light-green-text.text-accent-4 {
+  color: #64dd17 !important;
+}
+
+.lime {
+  background-color: #cddc39 !important;
+}
+
+.lime-text {
+  color: #cddc39 !important;
+}
+
+.lime.lighten-5 {
+  background-color: #f9fbe7 !important;
+}
+
+.lime-text.text-lighten-5 {
+  color: #f9fbe7 !important;
+}
+
+.lime.lighten-4 {
+  background-color: #f0f4c3 !important;
+}
+
+.lime-text.text-lighten-4 {
+  color: #f0f4c3 !important;
+}
+
+.lime.lighten-3 {
+  background-color: #e6ee9c !important;
+}
+
+.lime-text.text-lighten-3 {
+  color: #e6ee9c !important;
+}
+
+.lime.lighten-2 {
+  background-color: #dce775 !important;
+}
+
+.lime-text.text-lighten-2 {
+  color: #dce775 !important;
+}
+
+.lime.lighten-1 {
+  background-color: #d4e157 !important;
+}
+
+.lime-text.text-lighten-1 {
+  color: #d4e157 !important;
+}
+
+.lime.darken-1 {
+  background-color: #c0ca33 !important;
+}
+
+.lime-text.text-darken-1 {
+  color: #c0ca33 !important;
+}
+
+.lime.darken-2 {
+  background-color: #afb42b !important;
+}
+
+.lime-text.text-darken-2 {
+  color: #afb42b !important;
+}
+
+.lime.darken-3 {
+  background-color: #9e9d24 !important;
+}
+
+.lime-text.text-darken-3 {
+  color: #9e9d24 !important;
+}
+
+.lime.darken-4 {
+  background-color: #827717 !important;
+}
+
+.lime-text.text-darken-4 {
+  color: #827717 !important;
+}
+
+.lime.accent-1 {
+  background-color: #f4ff81 !important;
+}
+
+.lime-text.text-accent-1 {
+  color: #f4ff81 !important;
+}
+
+.lime.accent-2 {
+  background-color: #eeff41 !important;
+}
+
+.lime-text.text-accent-2 {
+  color: #eeff41 !important;
+}
+
+.lime.accent-3 {
+  background-color: #c6ff00 !important;
+}
+
+.lime-text.text-accent-3 {
+  color: #c6ff00 !important;
+}
+
+.lime.accent-4 {
+  background-color: #aeea00 !important;
+}
+
+.lime-text.text-accent-4 {
+  color: #aeea00 !important;
+}
+
+.yellow {
+  background-color: #ffeb3b !important;
+}
+
+.yellow-text {
+  color: #ffeb3b !important;
+}
+
+.yellow.lighten-5 {
+  background-color: #fffde7 !important;
+}
+
+.yellow-text.text-lighten-5 {
+  color: #fffde7 !important;
+}
+
+.yellow.lighten-4 {
+  background-color: #fff9c4 !important;
+}
+
+.yellow-text.text-lighten-4 {
+  color: #fff9c4 !important;
+}
+
+.yellow.lighten-3 {
+  background-color: #fff59d !important;
+}
+
+.yellow-text.text-lighten-3 {
+  color: #fff59d !important;
+}
+
+.yellow.lighten-2 {
+  background-color: #fff176 !important;
+}
+
+.yellow-text.text-lighten-2 {
+  color: #fff176 !important;
+}
+
+.yellow.lighten-1 {
+  background-color: #ffee58 !important;
+}
+
+.yellow-text.text-lighten-1 {
+  color: #ffee58 !important;
+}
+
+.yellow.darken-1 {
+  background-color: #fdd835 !important;
+}
+
+.yellow-text.text-darken-1 {
+  color: #fdd835 !important;
+}
+
+.yellow.darken-2 {
+  background-color: #fbc02d !important;
+}
+
+.yellow-text.text-darken-2 {
+  color: #fbc02d !important;
+}
+
+.yellow.darken-3 {
+  background-color: #f9a825 !important;
+}
+
+.yellow-text.text-darken-3 {
+  color: #f9a825 !important;
+}
+
+.yellow.darken-4 {
+  background-color: #f57f17 !important;
+}
+
+.yellow-text.text-darken-4 {
+  color: #f57f17 !important;
+}
+
+.yellow.accent-1 {
+  background-color: #ffff8d !important;
+}
+
+.yellow-text.text-accent-1 {
+  color: #ffff8d !important;
+}
+
+.yellow.accent-2 {
+  background-color: #ffff00 !important;
+}
+
+.yellow-text.text-accent-2 {
+  color: #ffff00 !important;
+}
+
+.yellow.accent-3 {
+  background-color: #ffea00 !important;
+}
+
+.yellow-text.text-accent-3 {
+  color: #ffea00 !important;
+}
+
+.yellow.accent-4 {
+  background-color: #ffd600 !important;
+}
+
+.yellow-text.text-accent-4 {
+  color: #ffd600 !important;
+}
+
+.amber {
+  background-color: #ffc107 !important;
+}
+
+.amber-text {
+  color: #ffc107 !important;
+}
+
+.amber.lighten-5 {
+  background-color: #fff8e1 !important;
+}
+
+.amber-text.text-lighten-5 {
+  color: #fff8e1 !important;
+}
+
+.amber.lighten-4 {
+  background-color: #ffecb3 !important;
+}
+
+.amber-text.text-lighten-4 {
+  color: #ffecb3 !important;
+}
+
+.amber.lighten-3 {
+  background-color: #ffe082 !important;
+}
+
+.amber-text.text-lighten-3 {
+  color: #ffe082 !important;
+}
+
+.amber.lighten-2 {
+  background-color: #ffd54f !important;
+}
+
+.amber-text.text-lighten-2 {
+  color: #ffd54f !important;
+}
+
+.amber.lighten-1 {
+  background-color: #ffca28 !important;
+}
+
+.amber-text.text-lighten-1 {
+  color: #ffca28 !important;
+}
+
+.amber.darken-1 {
+  background-color: #ffb300 !important;
+}
+
+.amber-text.text-darken-1 {
+  color: #ffb300 !important;
+}
+
+.amber.darken-2 {
+  background-color: #ffa000 !important;
+}
+
+.amber-text.text-darken-2 {
+  color: #ffa000 !important;
+}
+
+.amber.darken-3 {
+  background-color: #ff8f00 !important;
+}
+
+.amber-text.text-darken-3 {
+  color: #ff8f00 !important;
+}
+
+.amber.darken-4 {
+  background-color: #ff6f00 !important;
+}
+
+.amber-text.text-darken-4 {
+  color: #ff6f00 !important;
+}
+
+.amber.accent-1 {
+  background-color: #ffe57f !important;
+}
+
+.amber-text.text-accent-1 {
+  color: #ffe57f !important;
+}
+
+.amber.accent-2 {
+  background-color: #ffd740 !important;
+}
+
+.amber-text.text-accent-2 {
+  color: #ffd740 !important;
+}
+
+.amber.accent-3 {
+  background-color: #ffc400 !important;
+}
+
+.amber-text.text-accent-3 {
+  color: #ffc400 !important;
+}
+
+.amber.accent-4 {
+  background-color: #ffab00 !important;
+}
+
+.amber-text.text-accent-4 {
+  color: #ffab00 !important;
+}
+
+.orange {
+  background-color: #ff9800 !important;
+}
+
+.orange-text {
+  color: #ff9800 !important;
+}
+
+.orange.lighten-5 {
+  background-color: #fff3e0 !important;
+}
+
+.orange-text.text-lighten-5 {
+  color: #fff3e0 !important;
+}
+
+.orange.lighten-4 {
+  background-color: #ffe0b2 !important;
+}
+
+.orange-text.text-lighten-4 {
+  color: #ffe0b2 !important;
+}
+
+.orange.lighten-3 {
+  background-color: #ffcc80 !important;
+}
+
+.orange-text.text-lighten-3 {
+  color: #ffcc80 !important;
+}
+
+.orange.lighten-2 {
+  background-color: #ffb74d !important;
+}
+
+.orange-text.text-lighten-2 {
+  color: #ffb74d !important;
+}
+
+.orange.lighten-1 {
+  background-color: #ffa726 !important;
+}
+
+.orange-text.text-lighten-1 {
+  color: #ffa726 !important;
+}
+
+.orange.darken-1 {
+  background-color: #fb8c00 !important;
+}
+
+.orange-text.text-darken-1 {
+  color: #fb8c00 !important;
+}
+
+.orange.darken-2 {
+  background-color: #f57c00 !important;
+}
+
+.orange-text.text-darken-2 {
+  color: #f57c00 !important;
+}
+
+.orange.darken-3 {
+  background-color: #ef6c00 !important;
+}
+
+.orange-text.text-darken-3 {
+  color: #ef6c00 !important;
+}
+
+.orange.darken-4 {
+  background-color: #e65100 !important;
+}
+
+.orange-text.text-darken-4 {
+  color: #e65100 !important;
+}
+
+.orange.accent-1 {
+  background-color: #ffd180 !important;
+}
+
+.orange-text.text-accent-1 {
+  color: #ffd180 !important;
+}
+
+.orange.accent-2 {
+  background-color: #ffab40 !important;
+}
+
+.orange-text.text-accent-2 {
+  color: #ffab40 !important;
+}
+
+.orange.accent-3 {
+  background-color: #ff9100 !important;
+}
+
+.orange-text.text-accent-3 {
+  color: #ff9100 !important;
+}
+
+.orange.accent-4 {
+  background-color: #ff6d00 !important;
+}
+
+.orange-text.text-accent-4 {
+  color: #ff6d00 !important;
+}
+
+.deep-orange {
+  background-color: #ff5722 !important;
+}
+
+.deep-orange-text {
+  color: #ff5722 !important;
+}
+
+.deep-orange.lighten-5 {
+  background-color: #fbe9e7 !important;
+}
+
+.deep-orange-text.text-lighten-5 {
+  color: #fbe9e7 !important;
+}
+
+.deep-orange.lighten-4 {
+  background-color: #ffccbc !important;
+}
+
+.deep-orange-text.text-lighten-4 {
+  color: #ffccbc !important;
+}
+
+.deep-orange.lighten-3 {
+  background-color: #ffab91 !important;
+}
+
+.deep-orange-text.text-lighten-3 {
+  color: #ffab91 !important;
+}
+
+.deep-orange.lighten-2 {
+  background-color: #ff8a65 !important;
+}
+
+.deep-orange-text.text-lighten-2 {
+  color: #ff8a65 !important;
+}
+
+.deep-orange.lighten-1 {
+  background-color: #ff7043 !important;
+}
+
+.deep-orange-text.text-lighten-1 {
+  color: #ff7043 !important;
+}
+
+.deep-orange.darken-1 {
+  background-color: #f4511e !important;
+}
+
+.deep-orange-text.text-darken-1 {
+  color: #f4511e !important;
+}
+
+.deep-orange.darken-2 {
+  background-color: #e64a19 !important;
+}
+
+.deep-orange-text.text-darken-2 {
+  color: #e64a19 !important;
+}
+
+.deep-orange.darken-3 {
+  background-color: #d84315 !important;
+}
+
+.deep-orange-text.text-darken-3 {
+  color: #d84315 !important;
+}
+
+.deep-orange.darken-4 {
+  background-color: #bf360c !important;
+}
+
+.deep-orange-text.text-darken-4 {
+  color: #bf360c !important;
+}
+
+.deep-orange.accent-1 {
+  background-color: #ff9e80 !important;
+}
+
+.deep-orange-text.text-accent-1 {
+  color: #ff9e80 !important;
+}
+
+.deep-orange.accent-2 {
+  background-color: #ff6e40 !important;
+}
+
+.deep-orange-text.text-accent-2 {
+  color: #ff6e40 !important;
+}
+
+.deep-orange.accent-3 {
+  background-color: #ff3d00 !important;
+}
+
+.deep-orange-text.text-accent-3 {
+  color: #ff3d00 !important;
+}
+
+.deep-orange.accent-4 {
+  background-color: #dd2c00 !important;
+}
+
+.deep-orange-text.text-accent-4 {
+  color: #dd2c00 !important;
+}
+
+.brown {
+  background-color: #795548 !important;
+}
+
+.brown-text {
+  color: #795548 !important;
+}
+
+.brown.lighten-5 {
+  background-color: #efebe9 !important;
+}
+
+.brown-text.text-lighten-5 {
+  color: #efebe9 !important;
+}
+
+.brown.lighten-4 {
+  background-color: #d7ccc8 !important;
+}
+
+.brown-text.text-lighten-4 {
+  color: #d7ccc8 !important;
+}
+
+.brown.lighten-3 {
+  background-color: #bcaaa4 !important;
+}
+
+.brown-text.text-lighten-3 {
+  color: #bcaaa4 !important;
+}
+
+.brown.lighten-2 {
+  background-color: #a1887f !important;
+}
+
+.brown-text.text-lighten-2 {
+  color: #a1887f !important;
+}
+
+.brown.lighten-1 {
+  background-color: #8d6e63 !important;
+}
+
+.brown-text.text-lighten-1 {
+  color: #8d6e63 !important;
+}
+
+.brown.darken-1 {
+  background-color: #6d4c41 !important;
+}
+
+.brown-text.text-darken-1 {
+  color: #6d4c41 !important;
+}
+
+.brown.darken-2 {
+  background-color: #5d4037 !important;
+}
+
+.brown-text.text-darken-2 {
+  color: #5d4037 !important;
+}
+
+.brown.darken-3 {
+  background-color: #4e342e !important;
+}
+
+.brown-text.text-darken-3 {
+  color: #4e342e !important;
+}
+
+.brown.darken-4 {
+  background-color: #3e2723 !important;
+}
+
+.brown-text.text-darken-4 {
+  color: #3e2723 !important;
+}
+
+.blue-grey {
+  background-color: #607d8b !important;
+}
+
+.blue-grey-text {
+  color: #607d8b !important;
+}
+
+.blue-grey.lighten-5 {
+  background-color: #eceff1 !important;
+}
+
+.blue-grey-text.text-lighten-5 {
+  color: #eceff1 !important;
+}
+
+.blue-grey.lighten-4 {
+  background-color: #cfd8dc !important;
+}
+
+.blue-grey-text.text-lighten-4 {
+  color: #cfd8dc !important;
+}
+
+.blue-grey.lighten-3 {
+  background-color: #b0bec5 !important;
+}
+
+.blue-grey-text.text-lighten-3 {
+  color: #b0bec5 !important;
+}
+
+.blue-grey.lighten-2 {
+  background-color: #90a4ae !important;
+}
+
+.blue-grey-text.text-lighten-2 {
+  color: #90a4ae !important;
+}
+
+.blue-grey.lighten-1 {
+  background-color: #78909c !important;
+}
+
+.blue-grey-text.text-lighten-1 {
+  color: #78909c !important;
+}
+
+.blue-grey.darken-1 {
+  background-color: #546e7a !important;
+}
+
+.blue-grey-text.text-darken-1 {
+  color: #546e7a !important;
+}
+
+.blue-grey.darken-2 {
+  background-color: #455a64 !important;
+}
+
+.blue-grey-text.text-darken-2 {
+  color: #455a64 !important;
+}
+
+.blue-grey.darken-3 {
+  background-color: #37474f !important;
+}
+
+.blue-grey-text.text-darken-3 {
+  color: #37474f !important;
+}
+
+.blue-grey.darken-4 {
+  background-color: #263238 !important;
+}
+
+.blue-grey-text.text-darken-4 {
+  color: #263238 !important;
+}
+
+.grey {
+  background-color: #9e9e9e !important;
+}
+
+.grey-text {
+  color: #9e9e9e !important;
+}
+
+.grey.lighten-5 {
+  background-color: #fafafa !important;
+}
+
+.grey-text.text-lighten-5 {
+  color: #fafafa !important;
+}
+
+.grey.lighten-4 {
+  background-color: #f5f5f5 !important;
+}
+
+.grey-text.text-lighten-4 {
+  color: #f5f5f5 !important;
+}
+
+.grey.lighten-3 {
+  background-color: #eeeeee !important;
+}
+
+.grey-text.text-lighten-3 {
+  color: #eeeeee !important;
+}
+
+.grey.lighten-2 {
+  background-color: #e0e0e0 !important;
+}
+
+.grey-text.text-lighten-2 {
+  color: #e0e0e0 !important;
+}
+
+.grey.lighten-1 {
+  background-color: #bdbdbd !important;
+}
+
+.grey-text.text-lighten-1 {
+  color: #bdbdbd !important;
+}
+
+.grey.darken-1 {
+  background-color: #757575 !important;
+}
+
+.grey-text.text-darken-1 {
+  color: #757575 !important;
+}
+
+.grey.darken-2 {
+  background-color: #616161 !important;
+}
+
+.grey-text.text-darken-2 {
+  color: #616161 !important;
+}
+
+.grey.darken-3 {
+  background-color: #424242 !important;
+}
+
+.grey-text.text-darken-3 {
+  color: #424242 !important;
+}
+
+.grey.darken-4 {
+  background-color: #212121 !important;
+}
+
+.grey-text.text-darken-4 {
+  color: #212121 !important;
+}
+
+.black {
+  background-color: #000000 !important;
+}
+
+.black-text {
+  color: #000000 !important;
+}
+
+.white {
+  background-color: #FFFFFF !important;
+}
+
+.white-text {
+  color: #FFFFFF !important;
+}
+
+.transparent {
+  background-color: transparent !important;
+}
+
+.transparent-text {
+  color: transparent !important;
+}
+
+/*! normalize.css v7.0.0 | MIT License | github.com/necolas/normalize.css */
+/* Document
+   ========================================================================== */
+/**
+ * 1. Correct the line height in all browsers.
+ * 2. Prevent adjustments of font size after orientation changes in
+ *    IE on Windows Phone and in iOS.
+ */
+html {
+  line-height: 1.15;
+  /* 1 */
+  -ms-text-size-adjust: 100%;
+  /* 2 */
+  -webkit-text-size-adjust: 100%;
+  /* 2 */
+}
+
+/* Sections
+   ========================================================================== */
+/**
+ * Remove the margin in all browsers (opinionated).
+ */
+body {
+  margin: 0;
+}
+
+/**
+ * Add the correct display in IE 9-.
+ */
+article,
+aside,
+footer,
+header,
+nav,
+section {
+  display: block;
+}
+
+/**
+ * Correct the font size and margin on `h1` elements within `section` and
+ * `article` contexts in Chrome, Firefox, and Safari.
+ */
+h1 {
+  font-size: 2em;
+  margin: 0.67em 0;
+}
+
+/* Grouping content
+   ========================================================================== */
+/**
+ * Add the correct display in IE 9-.
+ * 1. Add the correct display in IE.
+ */
+figcaption,
+figure,
+main {
+  /* 1 */
+  display: block;
+}
+
+/**
+ * Add the correct margin in IE 8.
+ */
+figure {
+  margin: 1em 40px;
+}
+
+/**
+ * 1. Add the correct box sizing in Firefox.
+ * 2. Show the overflow in Edge and IE.
+ */
+hr {
+  -webkit-box-sizing: content-box;
+          box-sizing: content-box;
+  /* 1 */
+  height: 0;
+  /* 1 */
+  overflow: visible;
+  /* 2 */
+}
+
+/**
+ * 1. Correct the inheritance and scaling of font size in all browsers.
+ * 2. Correct the odd `em` font sizing in all browsers.
+ */
+pre {
+  font-family: monospace, monospace;
+  /* 1 */
+  font-size: 1em;
+  /* 2 */
+}
+
+/* Text-level semantics
+   ========================================================================== */
+/**
+ * 1. Remove the gray background on active links in IE 10.
+ * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
+ */
+a {
+  background-color: transparent;
+  /* 1 */
+  -webkit-text-decoration-skip: objects;
+  /* 2 */
+}
+
+/**
+ * 1. Remove the bottom border in Chrome 57- and Firefox 39-.
+ * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
+ */
+abbr[title] {
+  border-bottom: none;
+  /* 1 */
+  text-decoration: underline;
+  /* 2 */
+  -webkit-text-decoration: underline dotted;
+     -moz-text-decoration: underline dotted;
+          text-decoration: underline dotted;
+  /* 2 */
+}
+
+/**
+ * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
+ */
+b,
+strong {
+  font-weight: inherit;
+}
+
+/**
+ * Add the correct font weight in Chrome, Edge, and Safari.
+ */
+b,
+strong {
+  font-weight: bolder;
+}
+
+/**
+ * 1. Correct the inheritance and scaling of font size in all browsers.
+ * 2. Correct the odd `em` font sizing in all browsers.
+ */
+code,
+kbd,
+samp {
+  font-family: monospace, monospace;
+  /* 1 */
+  font-size: 1em;
+  /* 2 */
+}
+
+/**
+ * Add the correct font style in Android 4.3-.
+ */
+dfn {
+  font-style: italic;
+}
+
+/**
+ * Add the correct background and color in IE 9-.
+ */
+mark {
+  background-color: #ff0;
+  color: #000;
+}
+
+/**
+ * Add the correct font size in all browsers.
+ */
+small {
+  font-size: 80%;
+}
+
+/**
+ * Prevent `sub` and `sup` elements from affecting the line height in
+ * all browsers.
+ */
+sub,
+sup {
+  font-size: 75%;
+  line-height: 0;
+  position: relative;
+  vertical-align: baseline;
+}
+
+sub {
+  bottom: -0.25em;
+}
+
+sup {
+  top: -0.5em;
+}
+
+/* Embedded content
+   ========================================================================== */
+/**
+ * Add the correct display in IE 9-.
+ */
+audio,
+video {
+  display: inline-block;
+}
+
+/**
+ * Add the correct display in iOS 4-7.
+ */
+audio:not([controls]) {
+  display: none;
+  height: 0;
+}
+
+/**
+ * Remove the border on images inside links in IE 10-.
+ */
+img {
+  border-style: none;
+}
+
+/**
+ * Hide the overflow in IE.
+ */
+svg:not(:root) {
+  overflow: hidden;
+}
+
+/* Forms
+   ========================================================================== */
+/**
+ * 1. Change the font styles in all browsers (opinionated).
+ * 2. Remove the margin in Firefox and Safari.
+ */
+button,
+input,
+optgroup,
+select,
+textarea {
+  font-family: sans-serif;
+  /* 1 */
+  font-size: 100%;
+  /* 1 */
+  line-height: 1.15;
+  /* 1 */
+  margin: 0;
+  /* 2 */
+}
+
+/**
+ * Show the overflow in IE.
+ * 1. Show the overflow in Edge.
+ */
+button,
+input {
+  /* 1 */
+  overflow: visible;
+}
+
+/**
+ * Remove the inheritance of text transform in Edge, Firefox, and IE.
+ * 1. Remove the inheritance of text transform in Firefox.
+ */
+button,
+select {
+  /* 1 */
+  text-transform: none;
+}
+
+/**
+ * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
+ *    controls in Android 4.
+ * 2. Correct the inability to style clickable types in iOS and Safari.
+ */
+button,
+html [type="button"],
+[type="reset"],
+[type="submit"] {
+  -webkit-appearance: button;
+  /* 2 */
+}
+
+/**
+ * Remove the inner border and padding in Firefox.
+ */
+button::-moz-focus-inner,
+[type="button"]::-moz-focus-inner,
+[type="reset"]::-moz-focus-inner,
+[type="submit"]::-moz-focus-inner {
+  border-style: none;
+  padding: 0;
+}
+
+/**
+ * Restore the focus styles unset by the previous rule.
+ */
+button:-moz-focusring,
+[type="button"]:-moz-focusring,
+[type="reset"]:-moz-focusring,
+[type="submit"]:-moz-focusring {
+  outline: 1px dotted ButtonText;
+}
+
+/**
+ * Correct the padding in Firefox.
+ */
+fieldset {
+  padding: 0.35em 0.75em 0.625em;
+}
+
+/**
+ * 1. Correct the text wrapping in Edge and IE.
+ * 2. Correct the color inheritance from `fieldset` elements in IE.
+ * 3. Remove the padding so developers are not caught out when they zero out
+ *    `fieldset` elements in all browsers.
+ */
+legend {
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box;
+  /* 1 */
+  color: inherit;
+  /* 2 */
+  display: table;
+  /* 1 */
+  max-width: 100%;
+  /* 1 */
+  padding: 0;
+  /* 3 */
+  white-space: normal;
+  /* 1 */
+}
+
+/**
+ * 1. Add the correct display in IE 9-.
+ * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
+ */
+progress {
+  display: inline-block;
+  /* 1 */
+  vertical-align: baseline;
+  /* 2 */
+}
+
+/**
+ * Remove the default vertical scrollbar in IE.
+ */
+textarea {
+  overflow: auto;
+}
+
+/**
+ * 1. Add the correct box sizing in IE 10-.
+ * 2. Remove the padding in IE 10-.
+ */
+[type="checkbox"],
+[type="radio"] {
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box;
+  /* 1 */
+  padding: 0;
+  /* 2 */
+}
+
+/**
+ * Correct the cursor style of increment and decrement buttons in Chrome.
+ */
+[type="number"]::-webkit-inner-spin-button,
+[type="number"]::-webkit-outer-spin-button {
+  height: auto;
+}
+
+/**
+ * 1. Correct the odd appearance in Chrome and Safari.
+ * 2. Correct the outline style in Safari.
+ */
+[type="search"] {
+  -webkit-appearance: textfield;
+  /* 1 */
+  outline-offset: -2px;
+  /* 2 */
+}
+
+/**
+ * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.
+ */
+[type="search"]::-webkit-search-cancel-button,
+[type="search"]::-webkit-search-decoration {
+  -webkit-appearance: none;
+}
+
+/**
+ * 1. Correct the inability to style clickable types in iOS and Safari.
+ * 2. Change font properties to `inherit` in Safari.
+ */
+::-webkit-file-upload-button {
+  -webkit-appearance: button;
+  /* 1 */
+  font: inherit;
+  /* 2 */
+}
+
+/* Interactive
+   ========================================================================== */
+/*
+ * Add the correct display in IE 9-.
+ * 1. Add the correct display in Edge, IE, and Firefox.
+ */
+details,
+menu {
+  display: block;
+}
+
+/*
+ * Add the correct display in all browsers.
+ */
+summary {
+  display: list-item;
+}
+
+/* Scripting
+   ========================================================================== */
+/**
+ * Add the correct display in IE 9-.
+ */
+canvas {
+  display: inline-block;
+}
+
+/**
+ * Add the correct display in IE.
+ */
+template {
+  display: none;
+}
+
+/* Hidden
+   ========================================================================== */
+/**
+ * Add the correct display in IE 10-.
+ */
+[hidden] {
+  display: none;
+}
+
+html {
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box;
+}
+
+*, *:before, *:after {
+  -webkit-box-sizing: inherit;
+          box-sizing: inherit;
+}
+
+button,
+input,
+optgroup,
+select,
+textarea {
+  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
+}
+
+ul:not(.browser-default) {
+  padding-left: 0;
+  list-style-type: none;
+}
+
+ul:not(.browser-default) > li {
+  list-style-type: none;
+}
+
+a {
+  color: #039be5;
+  text-decoration: none;
+  -webkit-tap-highlight-color: transparent;
+}
+
+.valign-wrapper {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-align: center;
+  -webkit-align-items: center;
+      -ms-flex-align: center;
+          align-items: center;
+}
+
+.clearfix {
+  clear: both;
+}
+
+.z-depth-0 {
+  -webkit-box-shadow: none !important;
+          box-shadow: none !important;
+}
+
+/* 2dp elevation modified*/
+.z-depth-1, nav, .card-panel, .card, .toast, .btn, .btn-large, .btn-small, .btn-floating, .dropdown-content, .collapsible, .sidenav {
+  -webkit-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 3px 1px -2px rgba(0, 0, 0, 0.12), 0 1px 5px 0 rgba(0, 0, 0, 0.2);
+          box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 3px 1px -2px rgba(0, 0, 0, 0.12), 0 1px 5px 0 rgba(0, 0, 0, 0.2);
+}
+
+.z-depth-1-half, .btn:hover, .btn-large:hover, .btn-small:hover, .btn-floating:hover {
+  -webkit-box-shadow: 0 3px 3px 0 rgba(0, 0, 0, 0.14), 0 1px 7px 0 rgba(0, 0, 0, 0.12), 0 3px 1px -1px rgba(0, 0, 0, 0.2);
+          box-shadow: 0 3px 3px 0 rgba(0, 0, 0, 0.14), 0 1px 7px 0 rgba(0, 0, 0, 0.12), 0 3px 1px -1px rgba(0, 0, 0, 0.2);
+}
+
+/* 6dp elevation modified*/
+.z-depth-2 {
+  -webkit-box-shadow: 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12), 0 2px 4px -1px rgba(0, 0, 0, 0.3);
+          box-shadow: 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12), 0 2px 4px -1px rgba(0, 0, 0, 0.3);
+}
+
+/* 12dp elevation modified*/
+.z-depth-3 {
+  -webkit-box-shadow: 0 8px 17px 2px rgba(0, 0, 0, 0.14), 0 3px 14px 2px rgba(0, 0, 0, 0.12), 0 5px 5px -3px rgba(0, 0, 0, 0.2);
+          box-shadow: 0 8px 17px 2px rgba(0, 0, 0, 0.14), 0 3px 14px 2px rgba(0, 0, 0, 0.12), 0 5px 5px -3px rgba(0, 0, 0, 0.2);
+}
+
+/* 16dp elevation */
+.z-depth-4 {
+  -webkit-box-shadow: 0 16px 24px 2px rgba(0, 0, 0, 0.14), 0 6px 30px 5px rgba(0, 0, 0, 0.12), 0 8px 10px -7px rgba(0, 0, 0, 0.2);
+          box-shadow: 0 16px 24px 2px rgba(0, 0, 0, 0.14), 0 6px 30px 5px rgba(0, 0, 0, 0.12), 0 8px 10px -7px rgba(0, 0, 0, 0.2);
+}
+
+/* 24dp elevation */
+.z-depth-5, .modal {
+  -webkit-box-shadow: 0 24px 38px 3px rgba(0, 0, 0, 0.14), 0 9px 46px 8px rgba(0, 0, 0, 0.12), 0 11px 15px -7px rgba(0, 0, 0, 0.2);
+          box-shadow: 0 24px 38px 3px rgba(0, 0, 0, 0.14), 0 9px 46px 8px rgba(0, 0, 0, 0.12), 0 11px 15px -7px rgba(0, 0, 0, 0.2);
+}
+
+.hoverable {
+  -webkit-transition: -webkit-box-shadow .25s;
+  transition: -webkit-box-shadow .25s;
+  transition: box-shadow .25s;
+  transition: box-shadow .25s, -webkit-box-shadow .25s;
+}
+
+.hoverable:hover {
+  -webkit-box-shadow: 0 8px 17px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
+          box-shadow: 0 8px 17px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
+}
+
+.divider {
+  height: 1px;
+  overflow: hidden;
+  background-color: #e0e0e0;
+}
+
+blockquote {
+  margin: 20px 0;
+  padding-left: 1.5rem;
+  border-left: 5px solid #ee6e73;
+}
+
+i {
+  line-height: inherit;
+}
+
+i.left {
+  float: left;
+  margin-right: 15px;
+}
+
+i.right {
+  float: right;
+  margin-left: 15px;
+}
+
+i.tiny {
+  font-size: 1rem;
+}
+
+i.small {
+  font-size: 2rem;
+}
+
+i.medium {
+  font-size: 4rem;
+}
+
+i.large {
+  font-size: 6rem;
+}
+
+img.responsive-img,
+video.responsive-video {
+  max-width: 100%;
+  height: auto;
+}
+
+.pagination li {
+  display: inline-block;
+  border-radius: 2px;
+  text-align: center;
+  vertical-align: top;
+  height: 30px;
+}
+
+.pagination li a {
+  color: #444;
+  display: inline-block;
+  font-size: 1.2rem;
+  padding: 0 10px;
+  line-height: 30px;
+}
+
+.pagination li.active a {
+  color: #fff;
+}
+
+.pagination li.active {
+  background-color: #ee6e73;
+}
+
+.pagination li.disabled a {
+  cursor: default;
+  color: #999;
+}
+
+.pagination li i {
+  font-size: 2rem;
+}
+
+.pagination li.pages ul li {
+  display: inline-block;
+  float: none;
+}
+
+@media only screen and (max-width: 992px) {
+  .pagination {
+    width: 100%;
+  }
+  .pagination li.prev,
+  .pagination li.next {
+    width: 10%;
+  }
+  .pagination li.pages {
+    width: 80%;
+    overflow: hidden;
+    white-space: nowrap;
+  }
+}
+
+.breadcrumb {
+  font-size: 18px;
+  color: rgba(255, 255, 255, 0.7);
+}
+
+.breadcrumb i,
+.breadcrumb [class^="mdi-"], .breadcrumb [class*="mdi-"],
+.breadcrumb i.material-icons {
+  display: inline-block;
+  float: left;
+  font-size: 24px;
+}
+
+.breadcrumb:before {
+  content: '\E5CC';
+  color: rgba(255, 255, 255, 0.7);
+  vertical-align: top;
+  display: inline-block;
+  font-family: 'Material Icons';
+  font-weight: normal;
+  font-style: normal;
+  font-size: 25px;
+  margin: 0 10px 0 8px;
+  -webkit-font-smoothing: antialiased;
+}
+
+.breadcrumb:first-child:before {
+  display: none;
+}
+
+.breadcrumb:last-child {
+  color: #fff;
+}
+
+.parallax-container {
+  position: relative;
+  overflow: hidden;
+  height: 500px;
+}
+
+.parallax-container .parallax {
+  position: absolute;
+  top: 0;
+  left: 0;
+  right: 0;
+  bottom: 0;
+  z-index: -1;
+}
+
+.parallax-container .parallax img {
+  opacity: 0;
+  position: absolute;
+  left: 50%;
+  bottom: 0;
+  min-width: 100%;
+  min-height: 100%;
+  -webkit-transform: translate3d(0, 0, 0);
+          transform: translate3d(0, 0, 0);
+  -webkit-transform: translateX(-50%);
+          transform: translateX(-50%);
+}
+
+.pin-top, .pin-bottom {
+  position: relative;
+}
+
+.pinned {
+  position: fixed !important;
+}
+
+/*********************
+  Transition Classes
+**********************/
+ul.staggered-list li {
+  opacity: 0;
+}
+
+.fade-in {
+  opacity: 0;
+  -webkit-transform-origin: 0 50%;
+          transform-origin: 0 50%;
+}
+
+/*********************
+  Media Query Classes
+**********************/
+@media only screen and (max-width: 600px) {
+  .hide-on-small-only, .hide-on-small-and-down {
+    display: none !important;
+  }
+}
+
+@media only screen and (max-width: 992px) {
+  .hide-on-med-and-down {
+    display: none !important;
+  }
+}
+
+@media only screen and (min-width: 601px) {
+  .hide-on-med-and-up {
+    display: none !important;
+  }
+}
+
+@media only screen and (min-width: 600px) and (max-width: 992px) {
+  .hide-on-med-only {
+    display: none !important;
+  }
+}
+
+@media only screen and (min-width: 993px) {
+  .hide-on-large-only {
+    display: none !important;
+  }
+}
+
+@media only screen and (min-width: 1201px) {
+  .hide-on-extra-large-only {
+    display: none !important;
+  }
+}
+
+@media only screen and (min-width: 1201px) {
+  .show-on-extra-large {
+    display: block !important;
+  }
+}
+
+@media only screen and (min-width: 993px) {
+  .show-on-large {
+    display: block !important;
+  }
+}
+
+@media only screen and (min-width: 600px) and (max-width: 992px) {
+  .show-on-medium {
+    display: block !important;
+  }
+}
+
+@media only screen and (max-width: 600px) {
+  .show-on-small {
+    display: block !important;
+  }
+}
+
+@media only screen and (min-width: 601px) {
+  .show-on-medium-and-up {
+    display: block !important;
+  }
+}
+
+@media only screen and (max-width: 992px) {
+  .show-on-medium-and-down {
+    display: block !important;
+  }
+}
+
+@media only screen and (max-width: 600px) {
+  .center-on-small-only {
+    text-align: center;
+  }
+}
+
+.page-footer {
+  padding-top: 20px;
+  color: #fff;
+  background-color: #ee6e73;
+}
+
+.page-footer .footer-copyright {
+  overflow: hidden;
+  min-height: 50px;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-align: center;
+  -webkit-align-items: center;
+      -ms-flex-align: center;
+          align-items: center;
+  -webkit-box-pack: justify;
+  -webkit-justify-content: space-between;
+      -ms-flex-pack: justify;
+          justify-content: space-between;
+  padding: 10px 0px;
+  color: rgba(255, 255, 255, 0.8);
+  background-color: rgba(51, 51, 51, 0.08);
+}
+
+table, th, td {
+  border: none;
+}
+
+table {
+  width: 100%;
+  display: table;
+  border-collapse: collapse;
+  border-spacing: 0;
+}
+
+table.striped tr {
+  border-bottom: none;
+}
+
+table.striped > tbody > tr:nth-child(odd) {
+  background-color: rgba(242, 242, 242, 0.5);
+}
+
+table.striped > tbody > tr > td {
+  border-radius: 0;
+}
+
+table.highlight > tbody > tr {
+  -webkit-transition: background-color .25s ease;
+  transition: background-color .25s ease;
+}
+
+table.highlight > tbody > tr:hover {
+  background-color: rgba(242, 242, 242, 0.5);
+}
+
+table.centered thead tr th, table.centered tbody tr td {
+  text-align: center;
+}
+
+tr {
+  border-bottom: 1px solid rgba(0, 0, 0, 0.12);
+}
+
+td, th {
+  padding: 15px 5px;
+  display: table-cell;
+  text-align: left;
+  vertical-align: middle;
+  border-radius: 2px;
+}
+
+@media only screen and (max-width: 992px) {
+  table.responsive-table {
+    width: 100%;
+    border-collapse: collapse;
+    border-spacing: 0;
+    display: block;
+    position: relative;
+    /* sort out borders */
+  }
+  table.responsive-table td:empty:before {
+    content: '\00a0';
+  }
+  table.responsive-table th,
+  table.responsive-table td {
+    margin: 0;
+    vertical-align: top;
+  }
+  table.responsive-table th {
+    text-align: left;
+  }
+  table.responsive-table thead {
+    display: block;
+    float: left;
+  }
+  table.responsive-table thead tr {
+    display: block;
+    padding: 0 10px 0 0;
+  }
+  table.responsive-table thead tr th::before {
+    content: "\00a0";
+  }
+  table.responsive-table tbody {
+    display: block;
+    width: auto;
+    position: relative;
+    overflow-x: auto;
+    white-space: nowrap;
+  }
+  table.responsive-table tbody tr {
+    display: inline-block;
+    vertical-align: top;
+  }
+  table.responsive-table th {
+    display: block;
+    text-align: right;
+  }
+  table.responsive-table td {
+    display: block;
+    min-height: 1.25em;
+    text-align: left;
+  }
+  table.responsive-table tr {
+    border-bottom: none;
+    padding: 0 10px;
+  }
+  table.responsive-table thead {
+    border: 0;
+    border-right: 1px solid rgba(0, 0, 0, 0.12);
+  }
+}
+
+.collection {
+  margin: 0.5rem 0 1rem 0;
+  border: 1px solid #e0e0e0;
+  border-radius: 2px;
+  overflow: hidden;
+  position: relative;
+}
+
+.collection .collection-item {
+  background-color: #fff;
+  line-height: 1.5rem;
+  padding: 10px 20px;
+  margin: 0;
+  border-bottom: 1px solid #e0e0e0;
+}
+
+.collection .collection-item.avatar {
+  min-height: 84px;
+  padding-left: 72px;
+  position: relative;
+}
+
+.collection .collection-item.avatar:not(.circle-clipper) > .circle,
+.collection .collection-item.avatar :not(.circle-clipper) > .circle {
+  position: absolute;
+  width: 42px;
+  height: 42px;
+  overflow: hidden;
+  left: 15px;
+  display: inline-block;
+  vertical-align: middle;
+}
+
+.collection .collection-item.avatar i.circle {
+  font-size: 18px;
+  line-height: 42px;
+  color: #fff;
+  background-color: #999;
+  text-align: center;
+}
+
+.collection .collection-item.avatar .title {
+  font-size: 16px;
+}
+
+.collection .collection-item.avatar p {
+  margin: 0;
+}
+
+.collection .collection-item.avatar .secondary-content {
+  position: absolute;
+  top: 16px;
+  right: 16px;
+}
+
+.collection .collection-item:last-child {
+  border-bottom: none;
+}
+
+.collection .collection-item.active {
+  background-color: #26a69a;
+  color: #eafaf9;
+}
+
+.collection .collection-item.active .secondary-content {
+  color: #fff;
+}
+
+.collection a.collection-item {
+  display: block;
+  -webkit-transition: .25s;
+  transition: .25s;
+  color: #26a69a;
+}
+
+.collection a.collection-item:not(.active):hover {
+  background-color: #ddd;
+}
+
+.collection.with-header .collection-header {
+  background-color: #fff;
+  border-bottom: 1px solid #e0e0e0;
+  padding: 10px 20px;
+}
+
+.collection.with-header .collection-item {
+  padding-left: 30px;
+}
+
+.collection.with-header .collection-item.avatar {
+  padding-left: 72px;
+}
+
+.secondary-content {
+  float: right;
+  color: #26a69a;
+}
+
+.collapsible .collection {
+  margin: 0;
+  border: none;
+}
+
+.video-container {
+  position: relative;
+  padding-bottom: 56.25%;
+  height: 0;
+  overflow: hidden;
+}
+
+.video-container iframe, .video-container object, .video-container embed {
+  position: absolute;
+  top: 0;
+  left: 0;
+  width: 100%;
+  height: 100%;
+}
+
+.progress {
+  position: relative;
+  height: 4px;
+  display: block;
+  width: 100%;
+  background-color: #acece6;
+  border-radius: 2px;
+  margin: 0.5rem 0 1rem 0;
+  overflow: hidden;
+}
+
+.progress .determinate {
+  position: absolute;
+  top: 0;
+  left: 0;
+  bottom: 0;
+  background-color: #26a69a;
+  -webkit-transition: width .3s linear;
+  transition: width .3s linear;
+}
+
+.progress .indeterminate {
+  background-color: #26a69a;
+}
+
+.progress .indeterminate:before {
+  content: '';
+  position: absolute;
+  background-color: inherit;
+  top: 0;
+  left: 0;
+  bottom: 0;
+  will-change: left, right;
+  -webkit-animation: indeterminate 2.1s cubic-bezier(0.65, 0.815, 0.735, 0.395) infinite;
+          animation: indeterminate 2.1s cubic-bezier(0.65, 0.815, 0.735, 0.395) infinite;
+}
+
+.progress .indeterminate:after {
+  content: '';
+  position: absolute;
+  background-color: inherit;
+  top: 0;
+  left: 0;
+  bottom: 0;
+  will-change: left, right;
+  -webkit-animation: indeterminate-short 2.1s cubic-bezier(0.165, 0.84, 0.44, 1) infinite;
+          animation: indeterminate-short 2.1s cubic-bezier(0.165, 0.84, 0.44, 1) infinite;
+  -webkit-animation-delay: 1.15s;
+          animation-delay: 1.15s;
+}
+
+@-webkit-keyframes indeterminate {
+  0% {
+    left: -35%;
+    right: 100%;
+  }
+  60% {
+    left: 100%;
+    right: -90%;
+  }
+  100% {
+    left: 100%;
+    right: -90%;
+  }
+}
+
+@keyframes indeterminate {
+  0% {
+    left: -35%;
+    right: 100%;
+  }
+  60% {
+    left: 100%;
+    right: -90%;
+  }
+  100% {
+    left: 100%;
+    right: -90%;
+  }
+}
+
+@-webkit-keyframes indeterminate-short {
+  0% {
+    left: -200%;
+    right: 100%;
+  }
+  60% {
+    left: 107%;
+    right: -8%;
+  }
+  100% {
+    left: 107%;
+    right: -8%;
+  }
+}
+
+@keyframes indeterminate-short {
+  0% {
+    left: -200%;
+    right: 100%;
+  }
+  60% {
+    left: 107%;
+    right: -8%;
+  }
+  100% {
+    left: 107%;
+    right: -8%;
+  }
+}
+
+/*******************
+  Utility Classes
+*******************/
+.hide {
+  display: none !important;
+}
+
+.left-align {
+  text-align: left;
+}
+
+.right-align {
+  text-align: right;
+}
+
+.center, .center-align {
+  text-align: center;
+}
+
+.left {
+  float: left !important;
+}
+
+.right {
+  float: right !important;
+}
+
+.no-select, input[type=range],
+input[type=range] + .thumb {
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none;
+}
+
+.circle {
+  border-radius: 50%;
+}
+
+.center-block {
+  display: block;
+  margin-left: auto;
+  margin-right: auto;
+}
+
+.truncate {
+  display: block;
+  white-space: nowrap;
+  overflow: hidden;
+  text-overflow: ellipsis;
+}
+
+.no-padding {
+  padding: 0 !important;
+}
+
+span.badge {
+  min-width: 3rem;
+  padding: 0 6px;
+  margin-left: 14px;
+  text-align: center;
+  font-size: 1rem;
+  line-height: 22px;
+  height: 22px;
+  color: #757575;
+  float: right;
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box;
+}
+
+span.badge.new {
+  font-weight: 300;
+  font-size: 0.8rem;
+  color: #fff;
+  background-color: #26a69a;
+  border-radius: 2px;
+}
+
+span.badge.new:after {
+  content: " new";
+}
+
+span.badge[data-badge-caption]::after {
+  content: " " attr(data-badge-caption);
+}
+
+nav ul a span.badge {
+  display: inline-block;
+  float: none;
+  margin-left: 4px;
+  line-height: 22px;
+  height: 22px;
+  -webkit-font-smoothing: auto;
+}
+
+.collection-item span.badge {
+  margin-top: calc(0.75rem - 11px);
+}
+
+.collapsible span.badge {
+  margin-left: auto;
+}
+
+.sidenav span.badge {
+  margin-top: calc(24px - 11px);
+}
+
+table span.badge {
+  display: inline-block;
+  float: none;
+  margin-left: auto;
+}
+
+/* This is needed for some mobile phones to display the Google Icon font properly */
+.material-icons {
+  text-rendering: optimizeLegibility;
+  -webkit-font-feature-settings: 'liga';
+     -moz-font-feature-settings: 'liga';
+          font-feature-settings: 'liga';
+}
+
+.container {
+  margin: 0 auto;
+  max-width: 1280px;
+  width: 90%;
+}
+
+@media only screen and (min-width: 601px) {
+  .container {
+    width: 85%;
+  }
+}
+
+@media only screen and (min-width: 993px) {
+  .container {
+    width: 70%;
+  }
+}
+
+.col .row {
+  margin-left: -0.75rem;
+  margin-right: -0.75rem;
+}
+
+.section {
+  padding-top: 1rem;
+  padding-bottom: 1rem;
+}
+
+.section.no-pad {
+  padding: 0;
+}
+
+.section.no-pad-bot {
+  padding-bottom: 0;
+}
+
+.section.no-pad-top {
+  padding-top: 0;
+}
+
+.row {
+  margin-left: auto;
+  margin-right: auto;
+  margin-bottom: 20px;
+}
+
+.row:after {
+  content: "";
+  display: table;
+  clear: both;
+}
+
+.row .col {
+  float: left;
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box;
+  padding: 0 0.75rem;
+  min-height: 1px;
+}
+
+.row .col[class*="push-"], .row .col[class*="pull-"] {
+  position: relative;
+}
+
+.row .col.s1 {
+  width: 8.3333333333%;
+  margin-left: auto;
+  left: auto;
+  right: auto;
+}
+
+.row .col.s2 {
+  width: 16.6666666667%;
+  margin-left: auto;
+  left: auto;
+  right: auto;
+}
+
+.row .col.s3 {
+  width: 25%;
+  margin-left: auto;
+  left: auto;
+  right: auto;
+}
+
+.row .col.s4 {
+  width: 33.3333333333%;
+  margin-left: auto;
+  left: auto;
+  right: auto;
+}
+
+.row .col.s5 {
+  width: 41.6666666667%;
+  margin-left: auto;
+  left: auto;
+  right: auto;
+}
+
+.row .col.s6 {
+  width: 50%;
+  margin-left: auto;
+  left: auto;
+  right: auto;
+}
+
+.row .col.s7 {
+  width: 58.3333333333%;
+  margin-left: auto;
+  left: auto;
+  right: auto;
+}
+
+.row .col.s8 {
+  width: 66.6666666667%;
+  margin-left: auto;
+  left: auto;
+  right: auto;
+}
+
+.row .col.s9 {
+  width: 75%;
+  margin-left: auto;
+  left: auto;
+  right: auto;
+}
+
+.row .col.s10 {
+  width: 83.3333333333%;
+  margin-left: auto;
+  left: auto;
+  right: auto;
+}
+
+.row .col.s11 {
+  width: 91.6666666667%;
+  margin-left: auto;
+  left: auto;
+  right: auto;
+}
+
+.row .col.s12 {
+  width: 100%;
+  margin-left: auto;
+  left: auto;
+  right: auto;
+}
+
+.row .col.offset-s1 {
+  margin-left: 8.3333333333%;
+}
+
+.row .col.pull-s1 {
+  right: 8.3333333333%;
+}
+
+.row .col.push-s1 {
+  left: 8.3333333333%;
+}
+
+.row .col.offset-s2 {
+  margin-left: 16.6666666667%;
+}
+
+.row .col.pull-s2 {
+  right: 16.6666666667%;
+}
+
+.row .col.push-s2 {
+  left: 16.6666666667%;
+}
+
+.row .col.offset-s3 {
+  margin-left: 25%;
+}
+
+.row .col.pull-s3 {
+  right: 25%;
+}
+
+.row .col.push-s3 {
+  left: 25%;
+}
+
+.row .col.offset-s4 {
+  margin-left: 33.3333333333%;
+}
+
+.row .col.pull-s4 {
+  right: 33.3333333333%;
+}
+
+.row .col.push-s4 {
+  left: 33.3333333333%;
+}
+
+.row .col.offset-s5 {
+  margin-left: 41.6666666667%;
+}
+
+.row .col.pull-s5 {
+  right: 41.6666666667%;
+}
+
+.row .col.push-s5 {
+  left: 41.6666666667%;
+}
+
+.row .col.offset-s6 {
+  margin-left: 50%;
+}
+
+.row .col.pull-s6 {
+  right: 50%;
+}
+
+.row .col.push-s6 {
+  left: 50%;
+}
+
+.row .col.offset-s7 {
+  margin-left: 58.3333333333%;
+}
+
+.row .col.pull-s7 {
+  right: 58.3333333333%;
+}
+
+.row .col.push-s7 {
+  left: 58.3333333333%;
+}
+
+.row .col.offset-s8 {
+  margin-left: 66.6666666667%;
+}
+
+.row .col.pull-s8 {
+  right: 66.6666666667%;
+}
+
+.row .col.push-s8 {
+  left: 66.6666666667%;
+}
+
+.row .col.offset-s9 {
+  margin-left: 75%;
+}
+
+.row .col.pull-s9 {
+  right: 75%;
+}
+
+.row .col.push-s9 {
+  left: 75%;
+}
+
+.row .col.offset-s10 {
+  margin-left: 83.3333333333%;
+}
+
+.row .col.pull-s10 {
+  right: 83.3333333333%;
+}
+
+.row .col.push-s10 {
+  left: 83.3333333333%;
+}
+
+.row .col.offset-s11 {
+  margin-left: 91.6666666667%;
+}
+
+.row .col.pull-s11 {
+  right: 91.6666666667%;
+}
+
+.row .col.push-s11 {
+  left: 91.6666666667%;
+}
+
+.row .col.offset-s12 {
+  margin-left: 100%;
+}
+
+.row .col.pull-s12 {
+  right: 100%;
+}
+
+.row .col.push-s12 {
+  left: 100%;
+}
+
+@media only screen and (min-width: 601px) {
+  .row .col.m1 {
+    width: 8.3333333333%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.m2 {
+    width: 16.6666666667%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.m3 {
+    width: 25%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.m4 {
+    width: 33.3333333333%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.m5 {
+    width: 41.6666666667%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.m6 {
+    width: 50%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.m7 {
+    width: 58.3333333333%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.m8 {
+    width: 66.6666666667%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.m9 {
+    width: 75%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.m10 {
+    width: 83.3333333333%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.m11 {
+    width: 91.6666666667%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.m12 {
+    width: 100%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.offset-m1 {
+    margin-left: 8.3333333333%;
+  }
+  .row .col.pull-m1 {
+    right: 8.3333333333%;
+  }
+  .row .col.push-m1 {
+    left: 8.3333333333%;
+  }
+  .row .col.offset-m2 {
+    margin-left: 16.6666666667%;
+  }
+  .row .col.pull-m2 {
+    right: 16.6666666667%;
+  }
+  .row .col.push-m2 {
+    left: 16.6666666667%;
+  }
+  .row .col.offset-m3 {
+    margin-left: 25%;
+  }
+  .row .col.pull-m3 {
+    right: 25%;
+  }
+  .row .col.push-m3 {
+    left: 25%;
+  }
+  .row .col.offset-m4 {
+    margin-left: 33.3333333333%;
+  }
+  .row .col.pull-m4 {
+    right: 33.3333333333%;
+  }
+  .row .col.push-m4 {
+    left: 33.3333333333%;
+  }
+  .row .col.offset-m5 {
+    margin-left: 41.6666666667%;
+  }
+  .row .col.pull-m5 {
+    right: 41.6666666667%;
+  }
+  .row .col.push-m5 {
+    left: 41.6666666667%;
+  }
+  .row .col.offset-m6 {
+    margin-left: 50%;
+  }
+  .row .col.pull-m6 {
+    right: 50%;
+  }
+  .row .col.push-m6 {
+    left: 50%;
+  }
+  .row .col.offset-m7 {
+    margin-left: 58.3333333333%;
+  }
+  .row .col.pull-m7 {
+    right: 58.3333333333%;
+  }
+  .row .col.push-m7 {
+    left: 58.3333333333%;
+  }
+  .row .col.offset-m8 {
+    margin-left: 66.6666666667%;
+  }
+  .row .col.pull-m8 {
+    right: 66.6666666667%;
+  }
+  .row .col.push-m8 {
+    left: 66.6666666667%;
+  }
+  .row .col.offset-m9 {
+    margin-left: 75%;
+  }
+  .row .col.pull-m9 {
+    right: 75%;
+  }
+  .row .col.push-m9 {
+    left: 75%;
+  }
+  .row .col.offset-m10 {
+    margin-left: 83.3333333333%;
+  }
+  .row .col.pull-m10 {
+    right: 83.3333333333%;
+  }
+  .row .col.push-m10 {
+    left: 83.3333333333%;
+  }
+  .row .col.offset-m11 {
+    margin-left: 91.6666666667%;
+  }
+  .row .col.pull-m11 {
+    right: 91.6666666667%;
+  }
+  .row .col.push-m11 {
+    left: 91.6666666667%;
+  }
+  .row .col.offset-m12 {
+    margin-left: 100%;
+  }
+  .row .col.pull-m12 {
+    right: 100%;
+  }
+  .row .col.push-m12 {
+    left: 100%;
+  }
+}
+
+@media only screen and (min-width: 993px) {
+  .row .col.l1 {
+    width: 8.3333333333%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.l2 {
+    width: 16.6666666667%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.l3 {
+    width: 25%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.l4 {
+    width: 33.3333333333%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.l5 {
+    width: 41.6666666667%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.l6 {
+    width: 50%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.l7 {
+    width: 58.3333333333%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.l8 {
+    width: 66.6666666667%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.l9 {
+    width: 75%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.l10 {
+    width: 83.3333333333%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.l11 {
+    width: 91.6666666667%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.l12 {
+    width: 100%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.offset-l1 {
+    margin-left: 8.3333333333%;
+  }
+  .row .col.pull-l1 {
+    right: 8.3333333333%;
+  }
+  .row .col.push-l1 {
+    left: 8.3333333333%;
+  }
+  .row .col.offset-l2 {
+    margin-left: 16.6666666667%;
+  }
+  .row .col.pull-l2 {
+    right: 16.6666666667%;
+  }
+  .row .col.push-l2 {
+    left: 16.6666666667%;
+  }
+  .row .col.offset-l3 {
+    margin-left: 25%;
+  }
+  .row .col.pull-l3 {
+    right: 25%;
+  }
+  .row .col.push-l3 {
+    left: 25%;
+  }
+  .row .col.offset-l4 {
+    margin-left: 33.3333333333%;
+  }
+  .row .col.pull-l4 {
+    right: 33.3333333333%;
+  }
+  .row .col.push-l4 {
+    left: 33.3333333333%;
+  }
+  .row .col.offset-l5 {
+    margin-left: 41.6666666667%;
+  }
+  .row .col.pull-l5 {
+    right: 41.6666666667%;
+  }
+  .row .col.push-l5 {
+    left: 41.6666666667%;
+  }
+  .row .col.offset-l6 {
+    margin-left: 50%;
+  }
+  .row .col.pull-l6 {
+    right: 50%;
+  }
+  .row .col.push-l6 {
+    left: 50%;
+  }
+  .row .col.offset-l7 {
+    margin-left: 58.3333333333%;
+  }
+  .row .col.pull-l7 {
+    right: 58.3333333333%;
+  }
+  .row .col.push-l7 {
+    left: 58.3333333333%;
+  }
+  .row .col.offset-l8 {
+    margin-left: 66.6666666667%;
+  }
+  .row .col.pull-l8 {
+    right: 66.6666666667%;
+  }
+  .row .col.push-l8 {
+    left: 66.6666666667%;
+  }
+  .row .col.offset-l9 {
+    margin-left: 75%;
+  }
+  .row .col.pull-l9 {
+    right: 75%;
+  }
+  .row .col.push-l9 {
+    left: 75%;
+  }
+  .row .col.offset-l10 {
+    margin-left: 83.3333333333%;
+  }
+  .row .col.pull-l10 {
+    right: 83.3333333333%;
+  }
+  .row .col.push-l10 {
+    left: 83.3333333333%;
+  }
+  .row .col.offset-l11 {
+    margin-left: 91.6666666667%;
+  }
+  .row .col.pull-l11 {
+    right: 91.6666666667%;
+  }
+  .row .col.push-l11 {
+    left: 91.6666666667%;
+  }
+  .row .col.offset-l12 {
+    margin-left: 100%;
+  }
+  .row .col.pull-l12 {
+    right: 100%;
+  }
+  .row .col.push-l12 {
+    left: 100%;
+  }
+}
+
+@media only screen and (min-width: 1201px) {
+  .row .col.xl1 {
+    width: 8.3333333333%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.xl2 {
+    width: 16.6666666667%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.xl3 {
+    width: 25%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.xl4 {
+    width: 33.3333333333%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.xl5 {
+    width: 41.6666666667%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.xl6 {
+    width: 50%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.xl7 {
+    width: 58.3333333333%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.xl8 {
+    width: 66.6666666667%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.xl9 {
+    width: 75%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.xl10 {
+    width: 83.3333333333%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.xl11 {
+    width: 91.6666666667%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.xl12 {
+    width: 100%;
+    margin-left: auto;
+    left: auto;
+    right: auto;
+  }
+  .row .col.offset-xl1 {
+    margin-left: 8.3333333333%;
+  }
+  .row .col.pull-xl1 {
+    right: 8.3333333333%;
+  }
+  .row .col.push-xl1 {
+    left: 8.3333333333%;
+  }
+  .row .col.offset-xl2 {
+    margin-left: 16.6666666667%;
+  }
+  .row .col.pull-xl2 {
+    right: 16.6666666667%;
+  }
+  .row .col.push-xl2 {
+    left: 16.6666666667%;
+  }
+  .row .col.offset-xl3 {
+    margin-left: 25%;
+  }
+  .row .col.pull-xl3 {
+    right: 25%;
+  }
+  .row .col.push-xl3 {
+    left: 25%;
+  }
+  .row .col.offset-xl4 {
+    margin-left: 33.3333333333%;
+  }
+  .row .col.pull-xl4 {
+    right: 33.3333333333%;
+  }
+  .row .col.push-xl4 {
+    left: 33.3333333333%;
+  }
+  .row .col.offset-xl5 {
+    margin-left: 41.6666666667%;
+  }
+  .row .col.pull-xl5 {
+    right: 41.6666666667%;
+  }
+  .row .col.push-xl5 {
+    left: 41.6666666667%;
+  }
+  .row .col.offset-xl6 {
+    margin-left: 50%;
+  }
+  .row .col.pull-xl6 {
+    right: 50%;
+  }
+  .row .col.push-xl6 {
+    left: 50%;
+  }
+  .row .col.offset-xl7 {
+    margin-left: 58.3333333333%;
+  }
+  .row .col.pull-xl7 {
+    right: 58.3333333333%;
+  }
+  .row .col.push-xl7 {
+    left: 58.3333333333%;
+  }
+  .row .col.offset-xl8 {
+    margin-left: 66.6666666667%;
+  }
+  .row .col.pull-xl8 {
+    right: 66.6666666667%;
+  }
+  .row .col.push-xl8 {
+    left: 66.6666666667%;
+  }
+  .row .col.offset-xl9 {
+    margin-left: 75%;
+  }
+  .row .col.pull-xl9 {
+    right: 75%;
+  }
+  .row .col.push-xl9 {
+    left: 75%;
+  }
+  .row .col.offset-xl10 {
+    margin-left: 83.3333333333%;
+  }
+  .row .col.pull-xl10 {
+    right: 83.3333333333%;
+  }
+  .row .col.push-xl10 {
+    left: 83.3333333333%;
+  }
+  .row .col.offset-xl11 {
+    margin-left: 91.6666666667%;
+  }
+  .row .col.pull-xl11 {
+    right: 91.6666666667%;
+  }
+  .row .col.push-xl11 {
+    left: 91.6666666667%;
+  }
+  .row .col.offset-xl12 {
+    margin-left: 100%;
+  }
+  .row .col.pull-xl12 {
+    right: 100%;
+  }
+  .row .col.push-xl12 {
+    left: 100%;
+  }
+}
+
+nav {
+  color: #fff;
+  background-color: #ee6e73;
+  width: 100%;
+  height: 56px;
+  line-height: 56px;
+}
+
+nav.nav-extended {
+  height: auto;
+}
+
+nav.nav-extended .nav-wrapper {
+  min-height: 56px;
+  height: auto;
+}
+
+nav.nav-extended .nav-content {
+  position: relative;
+  line-height: normal;
+}
+
+nav a {
+  color: #fff;
+}
+
+nav i,
+nav [class^="mdi-"], nav [class*="mdi-"],
+nav i.material-icons {
+  display: block;
+  font-size: 24px;
+  height: 56px;
+  line-height: 56px;
+}
+
+nav .nav-wrapper {
+  position: relative;
+  height: 100%;
+}
+
+@media only screen and (min-width: 993px) {
+  nav a.sidenav-trigger {
+    display: none;
+  }
+}
+
+nav .sidenav-trigger {
+  float: left;
+  position: relative;
+  z-index: 1;
+  height: 56px;
+  margin: 0 18px;
+}
+
+nav .sidenav-trigger i {
+  height: 56px;
+  line-height: 56px;
+}
+
+nav .brand-logo {
+  position: absolute;
+  color: #fff;
+  display: inline-block;
+  font-size: 2.1rem;
+  padding: 0;
+}
+
+nav .brand-logo.center {
+  left: 50%;
+  -webkit-transform: translateX(-50%);
+          transform: translateX(-50%);
+}
+
+@media only screen and (max-width: 992px) {
+  nav .brand-logo {
+    left: 50%;
+    -webkit-transform: translateX(-50%);
+            transform: translateX(-50%);
+  }
+  nav .brand-logo.left, nav .brand-logo.right {
+    padding: 0;
+    -webkit-transform: none;
+            transform: none;
+  }
+  nav .brand-logo.left {
+    left: 0.5rem;
+  }
+  nav .brand-logo.right {
+    right: 0.5rem;
+    left: auto;
+  }
+}
+
+nav .brand-logo.right {
+  right: 0.5rem;
+  padding: 0;
+}
+
+nav .brand-logo i,
+nav .brand-logo [class^="mdi-"], nav .brand-logo [class*="mdi-"],
+nav .brand-logo i.material-icons {
+  float: left;
+  margin-right: 15px;
+}
+
+nav .nav-title {
+  display: inline-block;
+  font-size: 32px;
+  padding: 28px 0;
+}
+
+nav ul {
+  margin: 0;
+}
+
+nav ul li {
+  -webkit-transition: background-color .3s;
+  transition: background-color .3s;
+  float: left;
+  padding: 0;
+}
+
+nav ul li.active {
+  background-color: rgba(0, 0, 0, 0.1);
+}
+
+nav ul a {
+  -webkit-transition: background-color .3s;
+  transition: background-color .3s;
+  font-size: 1rem;
+  color: #fff;
+  display: block;
+  padding: 0 15px;
+  cursor: pointer;
+}
+
+nav ul a.btn, nav ul a.btn-large, nav ul a.btn-small, nav ul a.btn-large, nav ul a.btn-flat, nav ul a.btn-floating {
+  margin-top: -2px;
+  margin-left: 15px;
+  margin-right: 15px;
+}
+
+nav ul a.btn > .material-icons, nav ul a.btn-large > .material-icons, nav ul a.btn-small > .material-icons, nav ul a.btn-large > .material-icons, nav ul a.btn-flat > .material-icons, nav ul a.btn-floating > .material-icons {
+  height: inherit;
+  line-height: inherit;
+}
+
+nav ul a:hover {
+  background-color: rgba(0, 0, 0, 0.1);
+}
+
+nav ul.left {
+  float: left;
+}
+
+nav form {
+  height: 100%;
+}
+
+nav .input-field {
+  margin: 0;
+  height: 100%;
+}
+
+nav .input-field input {
+  height: 100%;
+  font-size: 1.2rem;
+  border: none;
+  padding-left: 2rem;
+}
+
+nav .input-field input:focus, nav .input-field input[type=text]:valid, nav .input-field input[type=password]:valid, nav .input-field input[type=email]:valid, nav .input-field input[type=url]:valid, nav .input-field input[type=date]:valid {
+  border: none;
+  -webkit-box-shadow: none;
+          box-shadow: none;
+}
+
+nav .input-field label {
+  top: 0;
+  left: 0;
+}
+
+nav .input-field label i {
+  color: rgba(255, 255, 255, 0.7);
+  -webkit-transition: color .3s;
+  transition: color .3s;
+}
+
+nav .input-field label.active i {
+  color: #fff;
+}
+
+.navbar-fixed {
+  position: relative;
+  height: 56px;
+  z-index: 997;
+}
+
+.navbar-fixed nav {
+  position: fixed;
+}
+
+@media only screen and (min-width: 601px) {
+  nav.nav-extended .nav-wrapper {
+    min-height: 64px;
+  }
+  nav, nav .nav-wrapper i, nav a.sidenav-trigger, nav a.sidenav-trigger i {
+    height: 64px;
+    line-height: 64px;
+  }
+  .navbar-fixed {
+    height: 64px;
+  }
+}
+
+a {
+  text-decoration: none;
+}
+
+html {
+  line-height: 1.5;
+  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
+  font-weight: normal;
+  color: rgba(0, 0, 0, 0.87);
+}
+
+@media only screen and (min-width: 0) {
+  html {
+    font-size: 14px;
+  }
+}
+
+@media only screen and (min-width: 992px) {
+  html {
+    font-size: 14.5px;
+  }
+}
+
+@media only screen and (min-width: 1200px) {
+  html {
+    font-size: 15px;
+  }
+}
+
+h1, h2, h3, h4, h5, h6 {
+  font-weight: 400;
+  line-height: 1.3;
+}
+
+h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
+  font-weight: inherit;
+}
+
+h1 {
+  font-size: 4.2rem;
+  line-height: 110%;
+  margin: 2.8rem 0 1.68rem 0;
+}
+
+h2 {
+  font-size: 3.56rem;
+  line-height: 110%;
+  margin: 2.3733333333rem 0 1.424rem 0;
+}
+
+h3 {
+  font-size: 2.92rem;
+  line-height: 110%;
+  margin: 1.9466666667rem 0 1.168rem 0;
+}
+
+h4 {
+  font-size: 2.28rem;
+  line-height: 110%;
+  margin: 1.52rem 0 0.912rem 0;
+}
+
+h5 {
+  font-size: 1.64rem;
+  line-height: 110%;
+  margin: 1.0933333333rem 0 0.656rem 0;
+}
+
+h6 {
+  font-size: 1.15rem;
+  line-height: 110%;
+  margin: 0.7666666667rem 0 0.46rem 0;
+}
+
+em {
+  font-style: italic;
+}
+
+strong {
+  font-weight: 500;
+}
+
+small {
+  font-size: 75%;
+}
+
+.light {
+  font-weight: 300;
+}
+
+.thin {
+  font-weight: 200;
+}
+
+@media only screen and (min-width: 360px) {
+  .flow-text {
+    font-size: 1.2rem;
+  }
+}
+
+@media only screen and (min-width: 390px) {
+  .flow-text {
+    font-size: 1.224rem;
+  }
+}
+
+@media only screen and (min-width: 420px) {
+  .flow-text {
+    font-size: 1.248rem;
+  }
+}
+
+@media only screen and (min-width: 450px) {
+  .flow-text {
+    font-size: 1.272rem;
+  }
+}
+
+@media only screen and (min-width: 480px) {
+  .flow-text {
+    font-size: 1.296rem;
+  }
+}
+
+@media only screen and (min-width: 510px) {
+  .flow-text {
+    font-size: 1.32rem;
+  }
+}
+
+@media only screen and (min-width: 540px) {
+  .flow-text {
+    font-size: 1.344rem;
+  }
+}
+
+@media only screen and (min-width: 570px) {
+  .flow-text {
+    font-size: 1.368rem;
+  }
+}
+
+@media only screen and (min-width: 600px) {
+  .flow-text {
+    font-size: 1.392rem;
+  }
+}
+
+@media only screen and (min-width: 630px) {
+  .flow-text {
+    font-size: 1.416rem;
+  }
+}
+
+@media only screen and (min-width: 660px) {
+  .flow-text {
+    font-size: 1.44rem;
+  }
+}
+
+@media only screen and (min-width: 690px) {
+  .flow-text {
+    font-size: 1.464rem;
+  }
+}
+
+@media only screen and (min-width: 720px) {
+  .flow-text {
+    font-size: 1.488rem;
+  }
+}
+
+@media only screen and (min-width: 750px) {
+  .flow-text {
+    font-size: 1.512rem;
+  }
+}
+
+@media only screen and (min-width: 780px) {
+  .flow-text {
+    font-size: 1.536rem;
+  }
+}
+
+@media only screen and (min-width: 810px) {
+  .flow-text {
+    font-size: 1.56rem;
+  }
+}
+
+@media only screen and (min-width: 840px) {
+  .flow-text {
+    font-size: 1.584rem;
+  }
+}
+
+@media only screen and (min-width: 870px) {
+  .flow-text {
+    font-size: 1.608rem;
+  }
+}
+
+@media only screen and (min-width: 900px) {
+  .flow-text {
+    font-size: 1.632rem;
+  }
+}
+
+@media only screen and (min-width: 930px) {
+  .flow-text {
+    font-size: 1.656rem;
+  }
+}
+
+@media only screen and (min-width: 960px) {
+  .flow-text {
+    font-size: 1.68rem;
+  }
+}
+
+@media only screen and (max-width: 360px) {
+  .flow-text {
+    font-size: 1.2rem;
+  }
+}
+
+.scale-transition {
+  -webkit-transition: -webkit-transform 0.3s cubic-bezier(0.53, 0.01, 0.36, 1.63) !important;
+  transition: -webkit-transform 0.3s cubic-bezier(0.53, 0.01, 0.36, 1.63) !important;
+  transition: transform 0.3s cubic-bezier(0.53, 0.01, 0.36, 1.63) !important;
+  transition: transform 0.3s cubic-bezier(0.53, 0.01, 0.36, 1.63), -webkit-transform 0.3s cubic-bezier(0.53, 0.01, 0.36, 1.63) !important;
+}
+
+.scale-transition.scale-out {
+  -webkit-transform: scale(0);
+          transform: scale(0);
+  -webkit-transition: -webkit-transform .2s !important;
+  transition: -webkit-transform .2s !important;
+  transition: transform .2s !important;
+  transition: transform .2s, -webkit-transform .2s !important;
+}
+
+.scale-transition.scale-in {
+  -webkit-transform: scale(1);
+          transform: scale(1);
+}
+
+.card-panel {
+  -webkit-transition: -webkit-box-shadow .25s;
+  transition: -webkit-box-shadow .25s;
+  transition: box-shadow .25s;
+  transition: box-shadow .25s, -webkit-box-shadow .25s;
+  padding: 24px;
+  margin: 0.5rem 0 1rem 0;
+  border-radius: 2px;
+  background-color: #fff;
+}
+
+.card {
+  position: relative;
+  margin: 0.5rem 0 1rem 0;
+  background-color: #fff;
+  -webkit-transition: -webkit-box-shadow .25s;
+  transition: -webkit-box-shadow .25s;
+  transition: box-shadow .25s;
+  transition: box-shadow .25s, -webkit-box-shadow .25s;
+  border-radius: 2px;
+}
+
+.card .card-title {
+  font-size: 24px;
+  font-weight: 300;
+}
+
+.card .card-title.activator {
+  cursor: pointer;
+}
+
+.card.small, .card.medium, .card.large {
+  position: relative;
+}
+
+.card.small .card-image, .card.medium .card-image, .card.large .card-image {
+  max-height: 60%;
+  overflow: hidden;
+}
+
+.card.small .card-image + .card-content, .card.medium .card-image + .card-content, .card.large .card-image + .card-content {
+  max-height: 40%;
+}
+
+.card.small .card-content, .card.medium .card-content, .card.large .card-content {
+  max-height: 100%;
+  overflow: hidden;
+}
+
+.card.small .card-action, .card.medium .card-action, .card.large .card-action {
+  position: absolute;
+  bottom: 0;
+  left: 0;
+  right: 0;
+}
+
+.card.small {
+  height: 300px;
+}
+
+.card.medium {
+  height: 400px;
+}
+
+.card.large {
+  height: 500px;
+}
+
+.card.horizontal {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+}
+
+.card.horizontal.small .card-image, .card.horizontal.medium .card-image, .card.horizontal.large .card-image {
+  height: 100%;
+  max-height: none;
+  overflow: visible;
+}
+
+.card.horizontal.small .card-image img, .card.horizontal.medium .card-image img, .card.horizontal.large .card-image img {
+  height: 100%;
+}
+
+.card.horizontal .card-image {
+  max-width: 50%;
+}
+
+.card.horizontal .card-image img {
+  border-radius: 2px 0 0 2px;
+  max-width: 100%;
+  width: auto;
+}
+
+.card.horizontal .card-stacked {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-orient: vertical;
+  -webkit-box-direction: normal;
+  -webkit-flex-direction: column;
+      -ms-flex-direction: column;
+          flex-direction: column;
+  -webkit-box-flex: 1;
+  -webkit-flex: 1;
+      -ms-flex: 1;
+          flex: 1;
+  position: relative;
+}
+
+.card.horizontal .card-stacked .card-content {
+  -webkit-box-flex: 1;
+  -webkit-flex-grow: 1;
+      -ms-flex-positive: 1;
+          flex-grow: 1;
+}
+
+.card.sticky-action .card-action {
+  z-index: 2;
+}
+
+.card.sticky-action .card-reveal {
+  z-index: 1;
+  padding-bottom: 64px;
+}
+
+.card .card-image {
+  position: relative;
+}
+
+.card .card-image img {
+  display: block;
+  border-radius: 2px 2px 0 0;
+  position: relative;
+  left: 0;
+  right: 0;
+  top: 0;
+  bottom: 0;
+  width: 100%;
+}
+
+.card .card-image .card-title {
+  color: #fff;
+  position: absolute;
+  bottom: 0;
+  left: 0;
+  max-width: 100%;
+  padding: 24px;
+}
+
+.card .card-content {
+  padding: 24px;
+  border-radius: 0 0 2px 2px;
+}
+
+.card .card-content p {
+  margin: 0;
+}
+
+.card .card-content .card-title {
+  display: block;
+  line-height: 32px;
+  margin-bottom: 8px;
+}
+
+.card .card-content .card-title i {
+  line-height: 32px;
+}
+
+.card .card-action {
+  background-color: inherit;
+  border-top: 1px solid rgba(160, 160, 160, 0.2);
+  position: relative;
+  padding: 16px 24px;
+}
+
+.card .card-action:last-child {
+  border-radius: 0 0 2px 2px;
+}
+
+.card .card-action a:not(.btn):not(.btn-large):not(.btn-small):not(.btn-large):not(.btn-floating) {
+  color: #ffab40;
+  margin-right: 24px;
+  -webkit-transition: color .3s ease;
+  transition: color .3s ease;
+  text-transform: uppercase;
+}
+
+.card .card-action a:not(.btn):not(.btn-large):not(.btn-small):not(.btn-large):not(.btn-floating):hover {
+  color: #ffd8a6;
+}
+
+.card .card-reveal {
+  padding: 24px;
+  position: absolute;
+  background-color: #fff;
+  width: 100%;
+  overflow-y: auto;
+  left: 0;
+  top: 100%;
+  height: 100%;
+  z-index: 3;
+  display: none;
+}
+
+.card .card-reveal .card-title {
+  cursor: pointer;
+  display: block;
+}
+
+#toast-container {
+  display: block;
+  position: fixed;
+  z-index: 10000;
+}
+
+@media only screen and (max-width: 600px) {
+  #toast-container {
+    min-width: 100%;
+    bottom: 0%;
+  }
+}
+
+@media only screen and (min-width: 601px) and (max-width: 992px) {
+  #toast-container {
+    left: 5%;
+    bottom: 7%;
+    max-width: 90%;
+  }
+}
+
+@media only screen and (min-width: 993px) {
+  #toast-container {
+    top: 10%;
+    right: 7%;
+    max-width: 86%;
+  }
+}
+
+.toast {
+  border-radius: 2px;
+  top: 35px;
+  width: auto;
+  margin-top: 10px;
+  position: relative;
+  max-width: 100%;
+  height: auto;
+  min-height: 48px;
+  line-height: 1.5em;
+  background-color: #323232;
+  padding: 10px 25px;
+  font-size: 1.1rem;
+  font-weight: 300;
+  color: #fff;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-align: center;
+  -webkit-align-items: center;
+      -ms-flex-align: center;
+          align-items: center;
+  -webkit-box-pack: justify;
+  -webkit-justify-content: space-between;
+      -ms-flex-pack: justify;
+          justify-content: space-between;
+  cursor: default;
+}
+
+.toast .toast-action {
+  color: #eeff41;
+  font-weight: 500;
+  margin-right: -25px;
+  margin-left: 3rem;
+}
+
+.toast.rounded {
+  border-radius: 24px;
+}
+
+@media only screen and (max-width: 600px) {
+  .toast {
+    width: 100%;
+    border-radius: 0;
+  }
+}
+
+.tabs {
+  position: relative;
+  overflow-x: auto;
+  overflow-y: hidden;
+  height: 48px;
+  width: 100%;
+  background-color: #fff;
+  margin: 0 auto;
+  white-space: nowrap;
+}
+
+.tabs.tabs-transparent {
+  background-color: transparent;
+}
+
+.tabs.tabs-transparent .tab a,
+.tabs.tabs-transparent .tab.disabled a,
+.tabs.tabs-transparent .tab.disabled a:hover {
+  color: rgba(255, 255, 255, 0.7);
+}
+
+.tabs.tabs-transparent .tab a:hover,
+.tabs.tabs-transparent .tab a.active {
+  color: #fff;
+}
+
+.tabs.tabs-transparent .indicator {
+  background-color: #fff;
+}
+
+.tabs.tabs-fixed-width {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+}
+
+.tabs.tabs-fixed-width .tab {
+  -webkit-box-flex: 1;
+  -webkit-flex-grow: 1;
+      -ms-flex-positive: 1;
+          flex-grow: 1;
+}
+
+.tabs .tab {
+  display: inline-block;
+  text-align: center;
+  line-height: 48px;
+  height: 48px;
+  padding: 0;
+  margin: 0;
+  text-transform: uppercase;
+}
+
+.tabs .tab a {
+  color: rgba(238, 110, 115, 0.7);
+  display: block;
+  width: 100%;
+  height: 100%;
+  padding: 0 24px;
+  font-size: 14px;
+  text-overflow: ellipsis;
+  overflow: hidden;
+  -webkit-transition: color .28s ease, background-color .28s ease;
+  transition: color .28s ease, background-color .28s ease;
+}
+
+.tabs .tab a:focus, .tabs .tab a:focus.active {
+  background-color: rgba(246, 178, 181, 0.2);
+  outline: none;
+}
+
+.tabs .tab a:hover, .tabs .tab a.active {
+  background-color: transparent;
+  color: #ee6e73;
+}
+
+.tabs .tab.disabled a,
+.tabs .tab.disabled a:hover {
+  color: rgba(238, 110, 115, 0.4);
+  cursor: default;
+}
+
+.tabs .indicator {
+  position: absolute;
+  bottom: 0;
+  height: 2px;
+  background-color: #f6b2b5;
+  will-change: left, right;
+}
+
+@media only screen and (max-width: 992px) {
+  .tabs {
+    display: -webkit-box;
+    display: -webkit-flex;
+    display: -ms-flexbox;
+    display: flex;
+  }
+  .tabs .tab {
+    -webkit-box-flex: 1;
+    -webkit-flex-grow: 1;
+        -ms-flex-positive: 1;
+            flex-grow: 1;
+  }
+  .tabs .tab a {
+    padding: 0 12px;
+  }
+}
+
+.material-tooltip {
+  padding: 10px 8px;
+  font-size: 1rem;
+  z-index: 2000;
+  background-color: transparent;
+  border-radius: 2px;
+  color: #fff;
+  min-height: 36px;
+  line-height: 120%;
+  opacity: 0;
+  position: absolute;
+  text-align: center;
+  max-width: calc(100% - 4px);
+  overflow: hidden;
+  left: 0;
+  top: 0;
+  pointer-events: none;
+  visibility: hidden;
+  background-color: #323232;
+}
+
+.backdrop {
+  position: absolute;
+  opacity: 0;
+  height: 7px;
+  width: 14px;
+  border-radius: 0 0 50% 50%;
+  background-color: #323232;
+  z-index: -1;
+  -webkit-transform-origin: 50% 0%;
+          transform-origin: 50% 0%;
+  visibility: hidden;
+}
+
+.btn, .btn-large, .btn-small,
+.btn-flat {
+  border: none;
+  border-radius: 2px;
+  display: inline-block;
+  height: 36px;
+  line-height: 36px;
+  padding: 0 16px;
+  text-transform: uppercase;
+  vertical-align: middle;
+  -webkit-tap-highlight-color: transparent;
+}
+
+.btn.disabled, .disabled.btn-large, .disabled.btn-small,
+.btn-floating.disabled,
+.btn-large.disabled,
+.btn-small.disabled,
+.btn-flat.disabled,
+.btn:disabled,
+.btn-large:disabled,
+.btn-small:disabled,
+.btn-floating:disabled,
+.btn-large:disabled,
+.btn-small:disabled,
+.btn-flat:disabled,
+.btn[disabled],
+.btn-large[disabled],
+.btn-small[disabled],
+.btn-floating[disabled],
+.btn-large[disabled],
+.btn-small[disabled],
+.btn-flat[disabled] {
+  pointer-events: none;
+  background-color: #DFDFDF !important;
+  -webkit-box-shadow: none;
+          box-shadow: none;
+  color: #9F9F9F !important;
+  cursor: default;
+}
+
+.btn.disabled:hover, .disabled.btn-large:hover, .disabled.btn-small:hover,
+.btn-floating.disabled:hover,
+.btn-large.disabled:hover,
+.btn-small.disabled:hover,
+.btn-flat.disabled:hover,
+.btn:disabled:hover,
+.btn-large:disabled:hover,
+.btn-small:disabled:hover,
+.btn-floating:disabled:hover,
+.btn-large:disabled:hover,
+.btn-small:disabled:hover,
+.btn-flat:disabled:hover,
+.btn[disabled]:hover,
+.btn-large[disabled]:hover,
+.btn-small[disabled]:hover,
+.btn-floating[disabled]:hover,
+.btn-large[disabled]:hover,
+.btn-small[disabled]:hover,
+.btn-flat[disabled]:hover {
+  background-color: #DFDFDF !important;
+  color: #9F9F9F !important;
+}
+
+.btn, .btn-large, .btn-small,
+.btn-floating,
+.btn-large,
+.btn-small,
+.btn-flat {
+  font-size: 14px;
+  outline: 0;
+}
+
+.btn i, .btn-large i, .btn-small i,
+.btn-floating i,
+.btn-large i,
+.btn-small i,
+.btn-flat i {
+  font-size: 1.3rem;
+  line-height: inherit;
+}
+
+.btn:focus, .btn-large:focus, .btn-small:focus,
+.btn-floating:focus {
+  background-color: #1d7d74;
+}
+
+.btn, .btn-large, .btn-small {
+  text-decoration: none;
+  color: #fff;
+  background-color: #26a69a;
+  text-align: center;
+  letter-spacing: .5px;
+  -webkit-transition: background-color .2s ease-out;
+  transition: background-color .2s ease-out;
+  cursor: pointer;
+}
+
+.btn:hover, .btn-large:hover, .btn-small:hover {
+  background-color: #2bbbad;
+}
+
+.btn-floating {
+  display: inline-block;
+  color: #fff;
+  position: relative;
+  overflow: hidden;
+  z-index: 1;
+  width: 40px;
+  height: 40px;
+  line-height: 40px;
+  padding: 0;
+  background-color: #26a69a;
+  border-radius: 50%;
+  -webkit-transition: background-color .3s;
+  transition: background-color .3s;
+  cursor: pointer;
+  vertical-align: middle;
+}
+
+.btn-floating:hover {
+  background-color: #26a69a;
+}
+
+.btn-floating:before {
+  border-radius: 0;
+}
+
+.btn-floating.btn-large {
+  width: 56px;
+  height: 56px;
+  padding: 0;
+}
+
+.btn-floating.btn-large.halfway-fab {
+  bottom: -28px;
+}
+
+.btn-floating.btn-large i {
+  line-height: 56px;
+}
+
+.btn-floating.btn-small {
+  width: 32.4px;
+  height: 32.4px;
+}
+
+.btn-floating.btn-small.halfway-fab {
+  bottom: -16.2px;
+}
+
+.btn-floating.btn-small i {
+  line-height: 32.4px;
+}
+
+.btn-floating.halfway-fab {
+  position: absolute;
+  right: 24px;
+  bottom: -20px;
+}
+
+.btn-floating.halfway-fab.left {
+  right: auto;
+  left: 24px;
+}
+
+.btn-floating i {
+  width: inherit;
+  display: inline-block;
+  text-align: center;
+  color: #fff;
+  font-size: 1.6rem;
+  line-height: 40px;
+}
+
+button.btn-floating {
+  border: none;
+}
+
+.fixed-action-btn {
+  position: fixed;
+  right: 23px;
+  bottom: 23px;
+  padding-top: 15px;
+  margin-bottom: 0;
+  z-index: 997;
+}
+
+.fixed-action-btn.active ul {
+  visibility: visible;
+}
+
+.fixed-action-btn.direction-left, .fixed-action-btn.direction-right {
+  padding: 0 0 0 15px;
+}
+
+.fixed-action-btn.direction-left ul, .fixed-action-btn.direction-right ul {
+  text-align: right;
+  right: 64px;
+  top: 50%;
+  -webkit-transform: translateY(-50%);
+          transform: translateY(-50%);
+  height: 100%;
+  left: auto;
+  /*width 100% only goes to width of button container */
+  width: 500px;
+}
+
+.fixed-action-btn.direction-left ul li, .fixed-action-btn.direction-right ul li {
+  display: inline-block;
+  margin: 7.5px 15px 0 0;
+}
+
+.fixed-action-btn.direction-right {
+  padding: 0 15px 0 0;
+}
+
+.fixed-action-btn.direction-right ul {
+  text-align: left;
+  direction: rtl;
+  left: 64px;
+  right: auto;
+}
+
+.fixed-action-btn.direction-right ul li {
+  margin: 7.5px 0 0 15px;
+}
+
+.fixed-action-btn.direction-bottom {
+  padding: 0 0 15px 0;
+}
+
+.fixed-action-btn.direction-bottom ul {
+  top: 64px;
+  bottom: auto;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-orient: vertical;
+  -webkit-box-direction: reverse;
+  -webkit-flex-direction: column-reverse;
+      -ms-flex-direction: column-reverse;
+          flex-direction: column-reverse;
+}
+
+.fixed-action-btn.direction-bottom ul li {
+  margin: 15px 0 0 0;
+}
+
+.fixed-action-btn.toolbar {
+  padding: 0;
+  height: 56px;
+}
+
+.fixed-action-btn.toolbar.active > a i {
+  opacity: 0;
+}
+
+.fixed-action-btn.toolbar ul {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  top: 0;
+  bottom: 0;
+  z-index: 1;
+}
+
+.fixed-action-btn.toolbar ul li {
+  -webkit-box-flex: 1;
+  -webkit-flex: 1;
+      -ms-flex: 1;
+          flex: 1;
+  display: inline-block;
+  margin: 0;
+  height: 100%;
+  -webkit-transition: none;
+  transition: none;
+}
+
+.fixed-action-btn.toolbar ul li a {
+  display: block;
+  overflow: hidden;
+  position: relative;
+  width: 100%;
+  height: 100%;
+  background-color: transparent;
+  -webkit-box-shadow: none;
+          box-shadow: none;
+  color: #fff;
+  line-height: 56px;
+  z-index: 1;
+}
+
+.fixed-action-btn.toolbar ul li a i {
+  line-height: inherit;
+}
+
+.fixed-action-btn ul {
+  left: 0;
+  right: 0;
+  text-align: center;
+  position: absolute;
+  bottom: 64px;
+  margin: 0;
+  visibility: hidden;
+}
+
+.fixed-action-btn ul li {
+  margin-bottom: 15px;
+}
+
+.fixed-action-btn ul a.btn-floating {
+  opacity: 0;
+}
+
+.fixed-action-btn .fab-backdrop {
+  position: absolute;
+  top: 0;
+  left: 0;
+  z-index: -1;
+  width: 40px;
+  height: 40px;
+  background-color: #26a69a;
+  border-radius: 50%;
+  -webkit-transform: scale(0);
+          transform: scale(0);
+}
+
+.btn-flat {
+  -webkit-box-shadow: none;
+          box-shadow: none;
+  background-color: transparent;
+  color: #343434;
+  cursor: pointer;
+  -webkit-transition: background-color .2s;
+  transition: background-color .2s;
+}
+
+.btn-flat:focus, .btn-flat:hover {
+  -webkit-box-shadow: none;
+          box-shadow: none;
+}
+
+.btn-flat:focus {
+  background-color: rgba(0, 0, 0, 0.1);
+}
+
+.btn-flat.disabled, .btn-flat.btn-flat[disabled] {
+  background-color: transparent !important;
+  color: #b3b2b2 !important;
+  cursor: default;
+}
+
+.btn-large {
+  height: 54px;
+  line-height: 54px;
+  font-size: 15px;
+  padding: 0 28px;
+}
+
+.btn-large i {
+  font-size: 1.6rem;
+}
+
+.btn-small {
+  height: 32.4px;
+  line-height: 32.4px;
+  font-size: 13px;
+}
+
+.btn-small i {
+  font-size: 1.2rem;
+}
+
+.btn-block {
+  display: block;
+}
+
+.dropdown-content {
+  background-color: #fff;
+  margin: 0;
+  display: none;
+  min-width: 100px;
+  overflow-y: auto;
+  opacity: 0;
+  position: absolute;
+  left: 0;
+  top: 0;
+  z-index: 9999;
+  -webkit-transform-origin: 0 0;
+          transform-origin: 0 0;
+}
+
+.dropdown-content:focus {
+  outline: 0;
+}
+
+.dropdown-content li {
+  clear: both;
+  color: rgba(0, 0, 0, 0.87);
+  cursor: pointer;
+  min-height: 50px;
+  line-height: 1.5rem;
+  width: 100%;
+  text-align: left;
+}
+
+.dropdown-content li:hover, .dropdown-content li.active {
+  background-color: #eee;
+}
+
+.dropdown-content li:focus {
+  outline: none;
+}
+
+.dropdown-content li.divider {
+  min-height: 0;
+  height: 1px;
+}
+
+.dropdown-content li > a, .dropdown-content li > span {
+  font-size: 16px;
+  color: #26a69a;
+  display: block;
+  line-height: 22px;
+  padding: 14px 16px;
+}
+
+.dropdown-content li > span > label {
+  top: 1px;
+  left: 0;
+  height: 18px;
+}
+
+.dropdown-content li > a > i {
+  height: inherit;
+  line-height: inherit;
+  float: left;
+  margin: 0 24px 0 0;
+  width: 24px;
+}
+
+body.keyboard-focused .dropdown-content li:focus {
+  background-color: #dadada;
+}
+
+.input-field.col .dropdown-content [type="checkbox"] + label {
+  top: 1px;
+  left: 0;
+  height: 18px;
+  -webkit-transform: none;
+          transform: none;
+}
+
+.dropdown-trigger {
+  cursor: pointer;
+}
+
+/*!
+ * Waves v0.6.0
+ * http://fian.my.id/Waves
+ *
+ * Copyright 2014 Alfiana E. Sibuea and other contributors
+ * Released under the MIT license
+ * https://github.com/fians/Waves/blob/master/LICENSE
+ */
+.waves-effect {
+  position: relative;
+  cursor: pointer;
+  display: inline-block;
+  overflow: hidden;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none;
+  -webkit-tap-highlight-color: transparent;
+  vertical-align: middle;
+  z-index: 1;
+  -webkit-transition: .3s ease-out;
+  transition: .3s ease-out;
+}
+
+.waves-effect .waves-ripple {
+  position: absolute;
+  border-radius: 50%;
+  width: 20px;
+  height: 20px;
+  margin-top: -10px;
+  margin-left: -10px;
+  opacity: 0;
+  background: rgba(0, 0, 0, 0.2);
+  -webkit-transition: all 0.7s ease-out;
+  transition: all 0.7s ease-out;
+  -webkit-transition-property: opacity, -webkit-transform;
+  transition-property: opacity, -webkit-transform;
+  transition-property: transform, opacity;
+  transition-property: transform, opacity, -webkit-transform;
+  -webkit-transform: scale(0);
+          transform: scale(0);
+  pointer-events: none;
+}
+
+.waves-effect.waves-light .waves-ripple {
+  background-color: rgba(255, 255, 255, 0.45);
+}
+
+.waves-effect.waves-red .waves-ripple {
+  background-color: rgba(244, 67, 54, 0.7);
+}
+
+.waves-effect.waves-yellow .waves-ripple {
+  background-color: rgba(255, 235, 59, 0.7);
+}
+
+.waves-effect.waves-orange .waves-ripple {
+  background-color: rgba(255, 152, 0, 0.7);
+}
+
+.waves-effect.waves-purple .waves-ripple {
+  background-color: rgba(156, 39, 176, 0.7);
+}
+
+.waves-effect.waves-green .waves-ripple {
+  background-color: rgba(76, 175, 80, 0.7);
+}
+
+.waves-effect.waves-teal .waves-ripple {
+  background-color: rgba(0, 150, 136, 0.7);
+}
+
+.waves-effect input[type="button"], .waves-effect input[type="reset"], .waves-effect input[type="submit"] {
+  border: 0;
+  font-style: normal;
+  font-size: inherit;
+  text-transform: inherit;
+  background: none;
+}
+
+.waves-effect img {
+  position: relative;
+  z-index: -1;
+}
+
+.waves-notransition {
+  -webkit-transition: none !important;
+  transition: none !important;
+}
+
+.waves-circle {
+  -webkit-transform: translateZ(0);
+          transform: translateZ(0);
+  -webkit-mask-image: -webkit-radial-gradient(circle, white 100%, black 100%);
+}
+
+.waves-input-wrapper {
+  border-radius: 0.2em;
+  vertical-align: bottom;
+}
+
+.waves-input-wrapper .waves-button-input {
+  position: relative;
+  top: 0;
+  left: 0;
+  z-index: 1;
+}
+
+.waves-circle {
+  text-align: center;
+  width: 2.5em;
+  height: 2.5em;
+  line-height: 2.5em;
+  border-radius: 50%;
+  -webkit-mask-image: none;
+}
+
+.waves-block {
+  display: block;
+}
+
+/* Firefox Bug: link not triggered */
+.waves-effect .waves-ripple {
+  z-index: -1;
+}
+
+.modal {
+  display: none;
+  position: fixed;
+  left: 0;
+  right: 0;
+  background-color: #fafafa;
+  padding: 0;
+  max-height: 70%;
+  width: 55%;
+  margin: auto;
+  overflow-y: auto;
+  border-radius: 2px;
+  will-change: top, opacity;
+}
+
+.modal:focus {
+  outline: none;
+}
+
+@media only screen and (max-width: 992px) {
+  .modal {
+    width: 80%;
+  }
+}
+
+.modal h1, .modal h2, .modal h3, .modal h4 {
+  margin-top: 0;
+}
+
+.modal .modal-content {
+  padding: 24px;
+}
+
+.modal .modal-close {
+  cursor: pointer;
+}
+
+.modal .modal-footer {
+  border-radius: 0 0 2px 2px;
+  background-color: #fafafa;
+  padding: 4px 6px;
+  height: 56px;
+  width: 100%;
+  text-align: right;
+}
+
+.modal .modal-footer .btn, .modal .modal-footer .btn-large, .modal .modal-footer .btn-small, .modal .modal-footer .btn-flat {
+  margin: 6px 0;
+}
+
+.modal-overlay {
+  position: fixed;
+  z-index: 999;
+  top: -25%;
+  left: 0;
+  bottom: 0;
+  right: 0;
+  height: 125%;
+  width: 100%;
+  background: #000;
+  display: none;
+  will-change: opacity;
+}
+
+.modal.modal-fixed-footer {
+  padding: 0;
+  height: 70%;
+}
+
+.modal.modal-fixed-footer .modal-content {
+  position: absolute;
+  height: calc(100% - 56px);
+  max-height: 100%;
+  width: 100%;
+  overflow-y: auto;
+}
+
+.modal.modal-fixed-footer .modal-footer {
+  border-top: 1px solid rgba(0, 0, 0, 0.1);
+  position: absolute;
+  bottom: 0;
+}
+
+.modal.bottom-sheet {
+  top: auto;
+  bottom: -100%;
+  margin: 0;
+  width: 100%;
+  max-height: 45%;
+  border-radius: 0;
+  will-change: bottom, opacity;
+}
+
+.collapsible {
+  border-top: 1px solid #ddd;
+  border-right: 1px solid #ddd;
+  border-left: 1px solid #ddd;
+  margin: 0.5rem 0 1rem 0;
+}
+
+.collapsible-header {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  cursor: pointer;
+  -webkit-tap-highlight-color: transparent;
+  line-height: 1.5;
+  padding: 1rem;
+  background-color: #fff;
+  border-bottom: 1px solid #ddd;
+}
+
+.collapsible-header:focus {
+  outline: 0;
+}
+
+.collapsible-header i {
+  width: 2rem;
+  font-size: 1.6rem;
+  display: inline-block;
+  text-align: center;
+  margin-right: 1rem;
+}
+
+.keyboard-focused .collapsible-header:focus {
+  background-color: #eee;
+}
+
+.collapsible-body {
+  display: none;
+  border-bottom: 1px solid #ddd;
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box;
+  padding: 2rem;
+}
+
+.sidenav .collapsible,
+.sidenav.fixed .collapsible {
+  border: none;
+  -webkit-box-shadow: none;
+          box-shadow: none;
+}
+
+.sidenav .collapsible li,
+.sidenav.fixed .collapsible li {
+  padding: 0;
+}
+
+.sidenav .collapsible-header,
+.sidenav.fixed .collapsible-header {
+  background-color: transparent;
+  border: none;
+  line-height: inherit;
+  height: inherit;
+  padding: 0 16px;
+}
+
+.sidenav .collapsible-header:hover,
+.sidenav.fixed .collapsible-header:hover {
+  background-color: rgba(0, 0, 0, 0.05);
+}
+
+.sidenav .collapsible-header i,
+.sidenav.fixed .collapsible-header i {
+  line-height: inherit;
+}
+
+.sidenav .collapsible-body,
+.sidenav.fixed .collapsible-body {
+  border: 0;
+  background-color: #fff;
+}
+
+.sidenav .collapsible-body li a,
+.sidenav.fixed .collapsible-body li a {
+  padding: 0 23.5px 0 31px;
+}
+
+.collapsible.popout {
+  border: none;
+  -webkit-box-shadow: none;
+          box-shadow: none;
+}
+
+.collapsible.popout > li {
+  -webkit-box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12);
+          box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12);
+  margin: 0 24px;
+  -webkit-transition: margin 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94);
+  transition: margin 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94);
+}
+
+.collapsible.popout > li.active {
+  -webkit-box-shadow: 0 5px 11px 0 rgba(0, 0, 0, 0.18), 0 4px 15px 0 rgba(0, 0, 0, 0.15);
+          box-shadow: 0 5px 11px 0 rgba(0, 0, 0, 0.18), 0 4px 15px 0 rgba(0, 0, 0, 0.15);
+  margin: 16px 0;
+}
+
+.chip {
+  display: inline-block;
+  height: 32px;
+  font-size: 13px;
+  font-weight: 500;
+  color: rgba(0, 0, 0, 0.6);
+  line-height: 32px;
+  padding: 0 12px;
+  border-radius: 16px;
+  background-color: #e4e4e4;
+  margin-bottom: 5px;
+  margin-right: 5px;
+}
+
+.chip:focus {
+  outline: none;
+  background-color: #26a69a;
+  color: #fff;
+}
+
+.chip > img {
+  float: left;
+  margin: 0 8px 0 -12px;
+  height: 32px;
+  width: 32px;
+  border-radius: 50%;
+}
+
+.chip .close {
+  cursor: pointer;
+  float: right;
+  font-size: 16px;
+  line-height: 32px;
+  padding-left: 8px;
+}
+
+.chips {
+  border: none;
+  border-bottom: 1px solid #9e9e9e;
+  -webkit-box-shadow: none;
+          box-shadow: none;
+  margin: 0 0 8px 0;
+  min-height: 45px;
+  outline: none;
+  -webkit-transition: all .3s;
+  transition: all .3s;
+}
+
+.chips.focus {
+  border-bottom: 1px solid #26a69a;
+  -webkit-box-shadow: 0 1px 0 0 #26a69a;
+          box-shadow: 0 1px 0 0 #26a69a;
+}
+
+.chips:hover {
+  cursor: text;
+}
+
+.chips .input {
+  background: none;
+  border: 0;
+  color: rgba(0, 0, 0, 0.6);
+  display: inline-block;
+  font-size: 16px;
+  height: 3rem;
+  line-height: 32px;
+  outline: 0;
+  margin: 0;
+  padding: 0 !important;
+  width: 120px !important;
+}
+
+.chips .input:focus {
+  border: 0 !important;
+  -webkit-box-shadow: none !important;
+          box-shadow: none !important;
+}
+
+.chips .autocomplete-content {
+  margin-top: 0;
+  margin-bottom: 0;
+}
+
+.prefix ~ .chips {
+  margin-left: 3rem;
+  width: 92%;
+  width: calc(100% - 3rem);
+}
+
+.chips:empty ~ label {
+  font-size: 0.8rem;
+  -webkit-transform: translateY(-140%);
+          transform: translateY(-140%);
+}
+
+.materialboxed {
+  display: block;
+  cursor: -webkit-zoom-in;
+  cursor: zoom-in;
+  position: relative;
+  -webkit-transition: opacity .4s;
+  transition: opacity .4s;
+  -webkit-backface-visibility: hidden;
+}
+
+.materialboxed:hover:not(.active) {
+  opacity: .8;
+}
+
+.materialboxed.active {
+  cursor: -webkit-zoom-out;
+  cursor: zoom-out;
+}
+
+#materialbox-overlay {
+  position: fixed;
+  top: 0;
+  right: 0;
+  bottom: 0;
+  left: 0;
+  background-color: #292929;
+  z-index: 1000;
+  will-change: opacity;
+}
+
+.materialbox-caption {
+  position: fixed;
+  display: none;
+  color: #fff;
+  line-height: 50px;
+  bottom: 0;
+  left: 0;
+  width: 100%;
+  text-align: center;
+  padding: 0% 15%;
+  height: 50px;
+  z-index: 1000;
+  -webkit-font-smoothing: antialiased;
+}
+
+select:focus {
+  outline: 1px solid #c9f3ef;
+}
+
+button:focus {
+  outline: none;
+  background-color: #2ab7a9;
+}
+
+label {
+  font-size: 0.8rem;
+  color: #9e9e9e;
+}
+
+/* Text Inputs + Textarea
+   ========================================================================== */
+/* Style Placeholders */
+::-webkit-input-placeholder {
+  color: #d1d1d1;
+}
+::-moz-placeholder {
+  color: #d1d1d1;
+}
+:-ms-input-placeholder {
+  color: #d1d1d1;
+}
+::-ms-input-placeholder {
+  color: #d1d1d1;
+}
+::placeholder {
+  color: #d1d1d1;
+}
+
+/* Text inputs */
+input:not([type]),
+input[type=text]:not(.browser-default),
+input[type=password]:not(.browser-default),
+input[type=email]:not(.browser-default),
+input[type=url]:not(.browser-default),
+input[type=time]:not(.browser-default),
+input[type=date]:not(.browser-default),
+input[type=datetime]:not(.browser-default),
+input[type=datetime-local]:not(.browser-default),
+input[type=tel]:not(.browser-default),
+input[type=number]:not(.browser-default),
+input[type=search]:not(.browser-default),
+textarea.materialize-textarea {
+  background-color: transparent;
+  border: none;
+  border-bottom: 1px solid #9e9e9e;
+  border-radius: 0;
+  outline: none;
+  height: 3rem;
+  width: 100%;
+  font-size: 16px;
+  margin: 0 0 8px 0;
+  padding: 0;
+  -webkit-box-shadow: none;
+          box-shadow: none;
+  -webkit-box-sizing: content-box;
+          box-sizing: content-box;
+  -webkit-transition: border .3s, -webkit-box-shadow .3s;
+  transition: border .3s, -webkit-box-shadow .3s;
+  transition: box-shadow .3s, border .3s;
+  transition: box-shadow .3s, border .3s, -webkit-box-shadow .3s;
+}
+
+input:not([type]):disabled, input:not([type])[readonly="readonly"],
+input[type=text]:not(.browser-default):disabled,
+input[type=text]:not(.browser-default)[readonly="readonly"],
+input[type=password]:not(.browser-default):disabled,
+input[type=password]:not(.browser-default)[readonly="readonly"],
+input[type=email]:not(.browser-default):disabled,
+input[type=email]:not(.browser-default)[readonly="readonly"],
+input[type=url]:not(.browser-default):disabled,
+input[type=url]:not(.browser-default)[readonly="readonly"],
+input[type=time]:not(.browser-default):disabled,
+input[type=time]:not(.browser-default)[readonly="readonly"],
+input[type=date]:not(.browser-default):disabled,
+input[type=date]:not(.browser-default)[readonly="readonly"],
+input[type=datetime]:not(.browser-default):disabled,
+input[type=datetime]:not(.browser-default)[readonly="readonly"],
+input[type=datetime-local]:not(.browser-default):disabled,
+input[type=datetime-local]:not(.browser-default)[readonly="readonly"],
+input[type=tel]:not(.browser-default):disabled,
+input[type=tel]:not(.browser-default)[readonly="readonly"],
+input[type=number]:not(.browser-default):disabled,
+input[type=number]:not(.browser-default)[readonly="readonly"],
+input[type=search]:not(.browser-default):disabled,
+input[type=search]:not(.browser-default)[readonly="readonly"],
+textarea.materialize-textarea:disabled,
+textarea.materialize-textarea[readonly="readonly"] {
+  color: rgba(0, 0, 0, 0.42);
+  border-bottom: 1px dotted rgba(0, 0, 0, 0.42);
+}
+
+input:not([type]):disabled + label,
+input:not([type])[readonly="readonly"] + label,
+input[type=text]:not(.browser-default):disabled + label,
+input[type=text]:not(.browser-default)[readonly="readonly"] + label,
+input[type=password]:not(.browser-default):disabled + label,
+input[type=password]:not(.browser-default)[readonly="readonly"] + label,
+input[type=email]:not(.browser-default):disabled + label,
+input[type=email]:not(.browser-default)[readonly="readonly"] + label,
+input[type=url]:not(.browser-default):disabled + label,
+input[type=url]:not(.browser-default)[readonly="readonly"] + label,
+input[type=time]:not(.browser-default):disabled + label,
+input[type=time]:not(.browser-default)[readonly="readonly"] + label,
+input[type=date]:not(.browser-default):disabled + label,
+input[type=date]:not(.browser-default)[readonly="readonly"] + label,
+input[type=datetime]:not(.browser-default):disabled + label,
+input[type=datetime]:not(.browser-default)[readonly="readonly"] + label,
+input[type=datetime-local]:not(.browser-default):disabled + label,
+input[type=datetime-local]:not(.browser-default)[readonly="readonly"] + label,
+input[type=tel]:not(.browser-default):disabled + label,
+input[type=tel]:not(.browser-default)[readonly="readonly"] + label,
+input[type=number]:not(.browser-default):disabled + label,
+input[type=number]:not(.browser-default)[readonly="readonly"] + label,
+input[type=search]:not(.browser-default):disabled + label,
+input[type=search]:not(.browser-default)[readonly="readonly"] + label,
+textarea.materialize-textarea:disabled + label,
+textarea.materialize-textarea[readonly="readonly"] + label {
+  color: rgba(0, 0, 0, 0.42);
+}
+
+input:not([type]):focus:not([readonly]),
+input[type=text]:not(.browser-default):focus:not([readonly]),
+input[type=password]:not(.browser-default):focus:not([readonly]),
+input[type=email]:not(.browser-default):focus:not([readonly]),
+input[type=url]:not(.browser-default):focus:not([readonly]),
+input[type=time]:not(.browser-default):focus:not([readonly]),
+input[type=date]:not(.browser-default):focus:not([readonly]),
+input[type=datetime]:not(.browser-default):focus:not([readonly]),
+input[type=datetime-local]:not(.browser-default):focus:not([readonly]),
+input[type=tel]:not(.browser-default):focus:not([readonly]),
+input[type=number]:not(.browser-default):focus:not([readonly]),
+input[type=search]:not(.browser-default):focus:not([readonly]),
+textarea.materialize-textarea:focus:not([readonly]) {
+  border-bottom: 1px solid #26a69a;
+  -webkit-box-shadow: 0 1px 0 0 #26a69a;
+          box-shadow: 0 1px 0 0 #26a69a;
+}
+
+input:not([type]):focus:not([readonly]) + label,
+input[type=text]:not(.browser-default):focus:not([readonly]) + label,
+input[type=password]:not(.browser-default):focus:not([readonly]) + label,
+input[type=email]:not(.browser-default):focus:not([readonly]) + label,
+input[type=url]:not(.browser-default):focus:not([readonly]) + label,
+input[type=time]:not(.browser-default):focus:not([readonly]) + label,
+input[type=date]:not(.browser-default):focus:not([readonly]) + label,
+input[type=datetime]:not(.browser-default):focus:not([readonly]) + label,
+input[type=datetime-local]:not(.browser-default):focus:not([readonly]) + label,
+input[type=tel]:not(.browser-default):focus:not([readonly]) + label,
+input[type=number]:not(.browser-default):focus:not([readonly]) + label,
+input[type=search]:not(.browser-default):focus:not([readonly]) + label,
+textarea.materialize-textarea:focus:not([readonly]) + label {
+  color: #26a69a;
+}
+
+input:not([type]):focus.valid ~ label,
+input[type=text]:not(.browser-default):focus.valid ~ label,
+input[type=password]:not(.browser-default):focus.valid ~ label,
+input[type=email]:not(.browser-default):focus.valid ~ label,
+input[type=url]:not(.browser-default):focus.valid ~ label,
+input[type=time]:not(.browser-default):focus.valid ~ label,
+input[type=date]:not(.browser-default):focus.valid ~ label,
+input[type=datetime]:not(.browser-default):focus.valid ~ label,
+input[type=datetime-local]:not(.browser-default):focus.valid ~ label,
+input[type=tel]:not(.browser-default):focus.valid ~ label,
+input[type=number]:not(.browser-default):focus.valid ~ label,
+input[type=search]:not(.browser-default):focus.valid ~ label,
+textarea.materialize-textarea:focus.valid ~ label {
+  color: #4CAF50;
+}
+
+input:not([type]):focus.invalid ~ label,
+input[type=text]:not(.browser-default):focus.invalid ~ label,
+input[type=password]:not(.browser-default):focus.invalid ~ label,
+input[type=email]:not(.browser-default):focus.invalid ~ label,
+input[type=url]:not(.browser-default):focus.invalid ~ label,
+input[type=time]:not(.browser-default):focus.invalid ~ label,
+input[type=date]:not(.browser-default):focus.invalid ~ label,
+input[type=datetime]:not(.browser-default):focus.invalid ~ label,
+input[type=datetime-local]:not(.browser-default):focus.invalid ~ label,
+input[type=tel]:not(.browser-default):focus.invalid ~ label,
+input[type=number]:not(.browser-default):focus.invalid ~ label,
+input[type=search]:not(.browser-default):focus.invalid ~ label,
+textarea.materialize-textarea:focus.invalid ~ label {
+  color: #F44336;
+}
+
+input:not([type]).validate + label,
+input[type=text]:not(.browser-default).validate + label,
+input[type=password]:not(.browser-default).validate + label,
+input[type=email]:not(.browser-default).validate + label,
+input[type=url]:not(.browser-default).validate + label,
+input[type=time]:not(.browser-default).validate + label,
+input[type=date]:not(.browser-default).validate + label,
+input[type=datetime]:not(.browser-default).validate + label,
+input[type=datetime-local]:not(.browser-default).validate + label,
+input[type=tel]:not(.browser-default).validate + label,
+input[type=number]:not(.browser-default).validate + label,
+input[type=search]:not(.browser-default).validate + label,
+textarea.materialize-textarea.validate + label {
+  width: 100%;
+}
+
+/* Validation Sass Placeholders */
+input.valid:not([type]), input.valid:not([type]):focus,
+input.valid[type=text]:not(.browser-default),
+input.valid[type=text]:not(.browser-default):focus,
+input.valid[type=password]:not(.browser-default),
+input.valid[type=password]:not(.browser-default):focus,
+input.valid[type=email]:not(.browser-default),
+input.valid[type=email]:not(.browser-default):focus,
+input.valid[type=url]:not(.browser-default),
+input.valid[type=url]:not(.browser-default):focus,
+input.valid[type=time]:not(.browser-default),
+input.valid[type=time]:not(.browser-default):focus,
+input.valid[type=date]:not(.browser-default),
+input.valid[type=date]:not(.browser-default):focus,
+input.valid[type=datetime]:not(.browser-default),
+input.valid[type=datetime]:not(.browser-default):focus,
+input.valid[type=datetime-local]:not(.browser-default),
+input.valid[type=datetime-local]:not(.browser-default):focus,
+input.valid[type=tel]:not(.browser-default),
+input.valid[type=tel]:not(.browser-default):focus,
+input.valid[type=number]:not(.browser-default),
+input.valid[type=number]:not(.browser-default):focus,
+input.valid[type=search]:not(.browser-default),
+input.valid[type=search]:not(.browser-default):focus,
+textarea.materialize-textarea.valid,
+textarea.materialize-textarea.valid:focus, .select-wrapper.valid > input.select-dropdown {
+  border-bottom: 1px solid #4CAF50;
+  -webkit-box-shadow: 0 1px 0 0 #4CAF50;
+          box-shadow: 0 1px 0 0 #4CAF50;
+}
+
+input.invalid:not([type]), input.invalid:not([type]):focus,
+input.invalid[type=text]:not(.browser-default),
+input.invalid[type=text]:not(.browser-default):focus,
+input.invalid[type=password]:not(.browser-default),
+input.invalid[type=password]:not(.browser-default):focus,
+input.invalid[type=email]:not(.browser-default),
+input.invalid[type=email]:not(.browser-default):focus,
+input.invalid[type=url]:not(.browser-default),
+input.invalid[type=url]:not(.browser-default):focus,
+input.invalid[type=time]:not(.browser-default),
+input.invalid[type=time]:not(.browser-default):focus,
+input.invalid[type=date]:not(.browser-default),
+input.invalid[type=date]:not(.browser-default):focus,
+input.invalid[type=datetime]:not(.browser-default),
+input.invalid[type=datetime]:not(.browser-default):focus,
+input.invalid[type=datetime-local]:not(.browser-default),
+input.invalid[type=datetime-local]:not(.browser-default):focus,
+input.invalid[type=tel]:not(.browser-default),
+input.invalid[type=tel]:not(.browser-default):focus,
+input.invalid[type=number]:not(.browser-default),
+input.invalid[type=number]:not(.browser-default):focus,
+input.invalid[type=search]:not(.browser-default),
+input.invalid[type=search]:not(.browser-default):focus,
+textarea.materialize-textarea.invalid,
+textarea.materialize-textarea.invalid:focus, .select-wrapper.invalid > input.select-dropdown,
+.select-wrapper.invalid > input.select-dropdown:focus {
+  border-bottom: 1px solid #F44336;
+  -webkit-box-shadow: 0 1px 0 0 #F44336;
+          box-shadow: 0 1px 0 0 #F44336;
+}
+
+input:not([type]).valid ~ .helper-text[data-success],
+input:not([type]):focus.valid ~ .helper-text[data-success],
+input:not([type]).invalid ~ .helper-text[data-error],
+input:not([type]):focus.invalid ~ .helper-text[data-error],
+input[type=text]:not(.browser-default).valid ~ .helper-text[data-success],
+input[type=text]:not(.browser-default):focus.valid ~ .helper-text[data-success],
+input[type=text]:not(.browser-default).invalid ~ .helper-text[data-error],
+input[type=text]:not(.browser-default):focus.invalid ~ .helper-text[data-error],
+input[type=password]:not(.browser-default).valid ~ .helper-text[data-success],
+input[type=password]:not(.browser-default):focus.valid ~ .helper-text[data-success],
+input[type=password]:not(.browser-default).invalid ~ .helper-text[data-error],
+input[type=password]:not(.browser-default):focus.invalid ~ .helper-text[data-error],
+input[type=email]:not(.browser-default).valid ~ .helper-text[data-success],
+input[type=email]:not(.browser-default):focus.valid ~ .helper-text[data-success],
+input[type=email]:not(.browser-default).invalid ~ .helper-text[data-error],
+input[type=email]:not(.browser-default):focus.invalid ~ .helper-text[data-error],
+input[type=url]:not(.browser-default).valid ~ .helper-text[data-success],
+input[type=url]:not(.browser-default):focus.valid ~ .helper-text[data-success],
+input[type=url]:not(.browser-default).invalid ~ .helper-text[data-error],
+input[type=url]:not(.browser-default):focus.invalid ~ .helper-text[data-error],
+input[type=time]:not(.browser-default).valid ~ .helper-text[data-success],
+input[type=time]:not(.browser-default):focus.valid ~ .helper-text[data-success],
+input[type=time]:not(.browser-default).invalid ~ .helper-text[data-error],
+input[type=time]:not(.browser-default):focus.invalid ~ .helper-text[data-error],
+input[type=date]:not(.browser-default).valid ~ .helper-text[data-success],
+input[type=date]:not(.browser-default):focus.valid ~ .helper-text[data-success],
+input[type=date]:not(.browser-default).invalid ~ .helper-text[data-error],
+input[type=date]:not(.browser-default):focus.invalid ~ .helper-text[data-error],
+input[type=datetime]:not(.browser-default).valid ~ .helper-text[data-success],
+input[type=datetime]:not(.browser-default):focus.valid ~ .helper-text[data-success],
+input[type=datetime]:not(.browser-default).invalid ~ .helper-text[data-error],
+input[type=datetime]:not(.browser-default):focus.invalid ~ .helper-text[data-error],
+input[type=datetime-local]:not(.browser-default).valid ~ .helper-text[data-success],
+input[type=datetime-local]:not(.browser-default):focus.valid ~ .helper-text[data-success],
+input[type=datetime-local]:not(.browser-default).invalid ~ .helper-text[data-error],
+input[type=datetime-local]:not(.browser-default):focus.invalid ~ .helper-text[data-error],
+input[type=tel]:not(.browser-default).valid ~ .helper-text[data-success],
+input[type=tel]:not(.browser-default):focus.valid ~ .helper-text[data-success],
+input[type=tel]:not(.browser-default).invalid ~ .helper-text[data-error],
+input[type=tel]:not(.browser-default):focus.invalid ~ .helper-text[data-error],
+input[type=number]:not(.browser-default).valid ~ .helper-text[data-success],
+input[type=number]:not(.browser-default):focus.valid ~ .helper-text[data-success],
+input[type=number]:not(.browser-default).invalid ~ .helper-text[data-error],
+input[type=number]:not(.browser-default):focus.invalid ~ .helper-text[data-error],
+input[type=search]:not(.browser-default).valid ~ .helper-text[data-success],
+input[type=search]:not(.browser-default):focus.valid ~ .helper-text[data-success],
+input[type=search]:not(.browser-default).invalid ~ .helper-text[data-error],
+input[type=search]:not(.browser-default):focus.invalid ~ .helper-text[data-error],
+textarea.materialize-textarea.valid ~ .helper-text[data-success],
+textarea.materialize-textarea:focus.valid ~ .helper-text[data-success],
+textarea.materialize-textarea.invalid ~ .helper-text[data-error],
+textarea.materialize-textarea:focus.invalid ~ .helper-text[data-error], .select-wrapper.valid .helper-text[data-success],
+.select-wrapper.invalid ~ .helper-text[data-error] {
+  color: transparent;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none;
+  pointer-events: none;
+}
+
+input:not([type]).valid ~ .helper-text:after,
+input:not([type]):focus.valid ~ .helper-text:after,
+input[type=text]:not(.browser-default).valid ~ .helper-text:after,
+input[type=text]:not(.browser-default):focus.valid ~ .helper-text:after,
+input[type=password]:not(.browser-default).valid ~ .helper-text:after,
+input[type=password]:not(.browser-default):focus.valid ~ .helper-text:after,
+input[type=email]:not(.browser-default).valid ~ .helper-text:after,
+input[type=email]:not(.browser-default):focus.valid ~ .helper-text:after,
+input[type=url]:not(.browser-default).valid ~ .helper-text:after,
+input[type=url]:not(.browser-default):focus.valid ~ .helper-text:after,
+input[type=time]:not(.browser-default).valid ~ .helper-text:after,
+input[type=time]:not(.browser-default):focus.valid ~ .helper-text:after,
+input[type=date]:not(.browser-default).valid ~ .helper-text:after,
+input[type=date]:not(.browser-default):focus.valid ~ .helper-text:after,
+input[type=datetime]:not(.browser-default).valid ~ .helper-text:after,
+input[type=datetime]:not(.browser-default):focus.valid ~ .helper-text:after,
+input[type=datetime-local]:not(.browser-default).valid ~ .helper-text:after,
+input[type=datetime-local]:not(.browser-default):focus.valid ~ .helper-text:after,
+input[type=tel]:not(.browser-default).valid ~ .helper-text:after,
+input[type=tel]:not(.browser-default):focus.valid ~ .helper-text:after,
+input[type=number]:not(.browser-default).valid ~ .helper-text:after,
+input[type=number]:not(.browser-default):focus.valid ~ .helper-text:after,
+input[type=search]:not(.browser-default).valid ~ .helper-text:after,
+input[type=search]:not(.browser-default):focus.valid ~ .helper-text:after,
+textarea.materialize-textarea.valid ~ .helper-text:after,
+textarea.materialize-textarea:focus.valid ~ .helper-text:after, .select-wrapper.valid ~ .helper-text:after {
+  content: attr(data-success);
+  color: #4CAF50;
+}
+
+input:not([type]).invalid ~ .helper-text:after,
+input:not([type]):focus.invalid ~ .helper-text:after,
+input[type=text]:not(.browser-default).invalid ~ .helper-text:after,
+input[type=text]:not(.browser-default):focus.invalid ~ .helper-text:after,
+input[type=password]:not(.browser-default).invalid ~ .helper-text:after,
+input[type=password]:not(.browser-default):focus.invalid ~ .helper-text:after,
+input[type=email]:not(.browser-default).invalid ~ .helper-text:after,
+input[type=email]:not(.browser-default):focus.invalid ~ .helper-text:after,
+input[type=url]:not(.browser-default).invalid ~ .helper-text:after,
+input[type=url]:not(.browser-default):focus.invalid ~ .helper-text:after,
+input[type=time]:not(.browser-default).invalid ~ .helper-text:after,
+input[type=time]:not(.browser-default):focus.invalid ~ .helper-text:after,
+input[type=date]:not(.browser-default).invalid ~ .helper-text:after,
+input[type=date]:not(.browser-default):focus.invalid ~ .helper-text:after,
+input[type=datetime]:not(.browser-default).invalid ~ .helper-text:after,
+input[type=datetime]:not(.browser-default):focus.invalid ~ .helper-text:after,
+input[type=datetime-local]:not(.browser-default).invalid ~ .helper-text:after,
+input[type=datetime-local]:not(.browser-default):focus.invalid ~ .helper-text:after,
+input[type=tel]:not(.browser-default).invalid ~ .helper-text:after,
+input[type=tel]:not(.browser-default):focus.invalid ~ .helper-text:after,
+input[type=number]:not(.browser-default).invalid ~ .helper-text:after,
+input[type=number]:not(.browser-default):focus.invalid ~ .helper-text:after,
+input[type=search]:not(.browser-default).invalid ~ .helper-text:after,
+input[type=search]:not(.browser-default):focus.invalid ~ .helper-text:after,
+textarea.materialize-textarea.invalid ~ .helper-text:after,
+textarea.materialize-textarea:focus.invalid ~ .helper-text:after, .select-wrapper.invalid ~ .helper-text:after {
+  content: attr(data-error);
+  color: #F44336;
+}
+
+input:not([type]) + label:after,
+input[type=text]:not(.browser-default) + label:after,
+input[type=password]:not(.browser-default) + label:after,
+input[type=email]:not(.browser-default) + label:after,
+input[type=url]:not(.browser-default) + label:after,
+input[type=time]:not(.browser-default) + label:after,
+input[type=date]:not(.browser-default) + label:after,
+input[type=datetime]:not(.browser-default) + label:after,
+input[type=datetime-local]:not(.browser-default) + label:after,
+input[type=tel]:not(.browser-default) + label:after,
+input[type=number]:not(.browser-default) + label:after,
+input[type=search]:not(.browser-default) + label:after,
+textarea.materialize-textarea + label:after, .select-wrapper + label:after {
+  display: block;
+  content: "";
+  position: absolute;
+  top: 100%;
+  left: 0;
+  opacity: 0;
+  -webkit-transition: .2s opacity ease-out, .2s color ease-out;
+  transition: .2s opacity ease-out, .2s color ease-out;
+}
+
+.input-field {
+  position: relative;
+  margin-top: 1rem;
+  margin-bottom: 1rem;
+}
+
+.input-field.inline {
+  display: inline-block;
+  vertical-align: middle;
+  margin-left: 5px;
+}
+
+.input-field.inline input,
+.input-field.inline .select-dropdown {
+  margin-bottom: 1rem;
+}
+
+.input-field.col label {
+  left: 0.75rem;
+}
+
+.input-field.col .prefix ~ label,
+.input-field.col .prefix ~ .validate ~ label {
+  width: calc(100% - 3rem - 1.5rem);
+}
+
+.input-field > label {
+  color: #9e9e9e;
+  position: absolute;
+  top: 0;
+  left: 0;
+  font-size: 1rem;
+  cursor: text;
+  -webkit-transition: color .2s ease-out, -webkit-transform .2s ease-out;
+  transition: color .2s ease-out, -webkit-transform .2s ease-out;
+  transition: transform .2s ease-out, color .2s ease-out;
+  transition: transform .2s ease-out, color .2s ease-out, -webkit-transform .2s ease-out;
+  -webkit-transform-origin: 0% 100%;
+          transform-origin: 0% 100%;
+  text-align: initial;
+  -webkit-transform: translateY(12px);
+          transform: translateY(12px);
+}
+
+.input-field > label:not(.label-icon).active {
+  -webkit-transform: translateY(-14px) scale(0.8);
+          transform: translateY(-14px) scale(0.8);
+  -webkit-transform-origin: 0 0;
+          transform-origin: 0 0;
+}
+
+.input-field > input[type]:-webkit-autofill:not(.browser-default):not([type="search"]) + label,
+.input-field > input[type=date]:not(.browser-default) + label,
+.input-field > input[type=time]:not(.browser-default) + label {
+  -webkit-transform: translateY(-14px) scale(0.8);
+          transform: translateY(-14px) scale(0.8);
+  -webkit-transform-origin: 0 0;
+          transform-origin: 0 0;
+}
+
+.input-field .helper-text {
+  position: relative;
+  min-height: 18px;
+  display: block;
+  font-size: 12px;
+  color: rgba(0, 0, 0, 0.54);
+}
+
+.input-field .helper-text::after {
+  opacity: 1;
+  position: absolute;
+  top: 0;
+  left: 0;
+}
+
+.input-field .prefix {
+  position: absolute;
+  width: 3rem;
+  font-size: 2rem;
+  -webkit-transition: color .2s;
+  transition: color .2s;
+  top: 0.5rem;
+}
+
+.input-field .prefix.active {
+  color: #26a69a;
+}
+
+.input-field .prefix ~ input,
+.input-field .prefix ~ textarea,
+.input-field .prefix ~ label,
+.input-field .prefix ~ .validate ~ label,
+.input-field .prefix ~ .helper-text,
+.input-field .prefix ~ .autocomplete-content {
+  margin-left: 3rem;
+  width: 92%;
+  width: calc(100% - 3rem);
+}
+
+.input-field .prefix ~ label {
+  margin-left: 3rem;
+}
+
+@media only screen and (max-width: 992px) {
+  .input-field .prefix ~ input {
+    width: 86%;
+    width: calc(100% - 3rem);
+  }
+}
+
+@media only screen and (max-width: 600px) {
+  .input-field .prefix ~ input {
+    width: 80%;
+    width: calc(100% - 3rem);
+  }
+}
+
+/* Search Field */
+.input-field input[type=search] {
+  display: block;
+  line-height: inherit;
+  -webkit-transition: .3s background-color;
+  transition: .3s background-color;
+}
+
+.nav-wrapper .input-field input[type=search] {
+  height: inherit;
+  padding-left: 4rem;
+  width: calc(100% - 4rem);
+  border: 0;
+  -webkit-box-shadow: none;
+          box-shadow: none;
+}
+
+.input-field input[type=search]:focus:not(.browser-default) {
+  background-color: #fff;
+  border: 0;
+  -webkit-box-shadow: none;
+          box-shadow: none;
+  color: #444;
+}
+
+.input-field input[type=search]:focus:not(.browser-default) + label i,
+.input-field input[type=search]:focus:not(.browser-default) ~ .mdi-navigation-close,
+.input-field input[type=search]:focus:not(.browser-default) ~ .material-icons {
+  color: #444;
+}
+
+.input-field input[type=search] + .label-icon {
+  -webkit-transform: none;
+          transform: none;
+  left: 1rem;
+}
+
+.input-field input[type=search] ~ .mdi-navigation-close,
+.input-field input[type=search] ~ .material-icons {
+  position: absolute;
+  top: 0;
+  right: 1rem;
+  color: transparent;
+  cursor: pointer;
+  font-size: 2rem;
+  -webkit-transition: .3s color;
+  transition: .3s color;
+}
+
+/* Textarea */
+textarea {
+  width: 100%;
+  height: 3rem;
+  background-color: transparent;
+}
+
+textarea.materialize-textarea {
+  line-height: normal;
+  overflow-y: hidden;
+  /* prevents scroll bar flash */
+  padding: .8rem 0 .8rem 0;
+  /* prevents text jump on Enter keypress */
+  resize: none;
+  min-height: 3rem;
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box;
+}
+
+.hiddendiv {
+  visibility: hidden;
+  white-space: pre-wrap;
+  word-wrap: break-word;
+  overflow-wrap: break-word;
+  /* future version of deprecated 'word-wrap' */
+  padding-top: 1.2rem;
+  /* prevents text jump on Enter keypress */
+  position: absolute;
+  top: 0;
+  z-index: -1;
+}
+
+/* Autocomplete */
+.autocomplete-content li .highlight {
+  color: #444;
+}
+
+.autocomplete-content li img {
+  height: 40px;
+  width: 40px;
+  margin: 5px 15px;
+}
+
+/* Character Counter */
+.character-counter {
+  min-height: 18px;
+}
+
+/* Radio Buttons
+   ========================================================================== */
+[type="radio"]:not(:checked),
+[type="radio"]:checked {
+  position: absolute;
+  opacity: 0;
+  pointer-events: none;
+}
+
+[type="radio"]:not(:checked) + span,
+[type="radio"]:checked + span {
+  position: relative;
+  padding-left: 35px;
+  cursor: pointer;
+  display: inline-block;
+  height: 25px;
+  line-height: 25px;
+  font-size: 1rem;
+  -webkit-transition: .28s ease;
+  transition: .28s ease;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none;
+}
+
+[type="radio"] + span:before,
+[type="radio"] + span:after {
+  content: '';
+  position: absolute;
+  left: 0;
+  top: 0;
+  margin: 4px;
+  width: 16px;
+  height: 16px;
+  z-index: 0;
+  -webkit-transition: .28s ease;
+  transition: .28s ease;
+}
+
+/* Unchecked styles */
+[type="radio"]:not(:checked) + span:before,
+[type="radio"]:not(:checked) + span:after,
+[type="radio"]:checked + span:before,
+[type="radio"]:checked + span:after,
+[type="radio"].with-gap:checked + span:before,
+[type="radio"].with-gap:checked + span:after {
+  border-radius: 50%;
+}
+
+[type="radio"]:not(:checked) + span:before,
+[type="radio"]:not(:checked) + span:after {
+  border: 2px solid #5a5a5a;
+}
+
+[type="radio"]:not(:checked) + span:after {
+  -webkit-transform: scale(0);
+          transform: scale(0);
+}
+
+/* Checked styles */
+[type="radio"]:checked + span:before {
+  border: 2px solid transparent;
+}
+
+[type="radio"]:checked + span:after,
+[type="radio"].with-gap:checked + span:before,
+[type="radio"].with-gap:checked + span:after {
+  border: 2px solid #26a69a;
+}
+
+[type="radio"]:checked + span:after,
+[type="radio"].with-gap:checked + span:after {
+  background-color: #26a69a;
+}
+
+[type="radio"]:checked + span:after {
+  -webkit-transform: scale(1.02);
+          transform: scale(1.02);
+}
+
+/* Radio With gap */
+[type="radio"].with-gap:checked + span:after {
+  -webkit-transform: scale(0.5);
+          transform: scale(0.5);
+}
+
+/* Focused styles */
+[type="radio"].tabbed:focus + span:before {
+  -webkit-box-shadow: 0 0 0 10px rgba(0, 0, 0, 0.1);
+          box-shadow: 0 0 0 10px rgba(0, 0, 0, 0.1);
+}
+
+/* Disabled Radio With gap */
+[type="radio"].with-gap:disabled:checked + span:before {
+  border: 2px solid rgba(0, 0, 0, 0.42);
+}
+
+[type="radio"].with-gap:disabled:checked + span:after {
+  border: none;
+  background-color: rgba(0, 0, 0, 0.42);
+}
+
+/* Disabled style */
+[type="radio"]:disabled:not(:checked) + span:before,
+[type="radio"]:disabled:checked + span:before {
+  background-color: transparent;
+  border-color: rgba(0, 0, 0, 0.42);
+}
+
+[type="radio"]:disabled + span {
+  color: rgba(0, 0, 0, 0.42);
+}
+
+[type="radio"]:disabled:not(:checked) + span:before {
+  border-color: rgba(0, 0, 0, 0.42);
+}
+
+[type="radio"]:disabled:checked + span:after {
+  background-color: rgba(0, 0, 0, 0.42);
+  border-color: #949494;
+}
+
+/* Checkboxes
+   ========================================================================== */
+/* Remove default checkbox */
+[type="checkbox"]:not(:checked),
+[type="checkbox"]:checked {
+  position: absolute;
+  opacity: 0;
+  pointer-events: none;
+}
+
+[type="checkbox"] {
+  /* checkbox aspect */
+}
+
+[type="checkbox"] + span:not(.lever) {
+  position: relative;
+  padding-left: 35px;
+  cursor: pointer;
+  display: inline-block;
+  height: 25px;
+  line-height: 25px;
+  font-size: 1rem;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none;
+}
+
+[type="checkbox"] + span:not(.lever):before,
+[type="checkbox"]:not(.filled-in) + span:not(.lever):after {
+  content: '';
+  position: absolute;
+  top: 0;
+  left: 0;
+  width: 18px;
+  height: 18px;
+  z-index: 0;
+  border: 2px solid #5a5a5a;
+  border-radius: 1px;
+  margin-top: 3px;
+  -webkit-transition: .2s;
+  transition: .2s;
+}
+
+[type="checkbox"]:not(.filled-in) + span:not(.lever):after {
+  border: 0;
+  -webkit-transform: scale(0);
+          transform: scale(0);
+}
+
+[type="checkbox"]:not(:checked):disabled + span:not(.lever):before {
+  border: none;
+  background-color: rgba(0, 0, 0, 0.42);
+}
+
+[type="checkbox"].tabbed:focus + span:not(.lever):after {
+  -webkit-transform: scale(1);
+          transform: scale(1);
+  border: 0;
+  border-radius: 50%;
+  -webkit-box-shadow: 0 0 0 10px rgba(0, 0, 0, 0.1);
+          box-shadow: 0 0 0 10px rgba(0, 0, 0, 0.1);
+  background-color: rgba(0, 0, 0, 0.1);
+}
+
+[type="checkbox"]:checked + span:not(.lever):before {
+  top: -4px;
+  left: -5px;
+  width: 12px;
+  height: 22px;
+  border-top: 2px solid transparent;
+  border-left: 2px solid transparent;
+  border-right: 2px solid #26a69a;
+  border-bottom: 2px solid #26a69a;
+  -webkit-transform: rotate(40deg);
+          transform: rotate(40deg);
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden;
+  -webkit-transform-origin: 100% 100%;
+          transform-origin: 100% 100%;
+}
+
+[type="checkbox"]:checked:disabled + span:before {
+  border-right: 2px solid rgba(0, 0, 0, 0.42);
+  border-bottom: 2px solid rgba(0, 0, 0, 0.42);
+}
+
+/* Indeterminate checkbox */
+[type="checkbox"]:indeterminate + span:not(.lever):before {
+  top: -11px;
+  left: -12px;
+  width: 10px;
+  height: 22px;
+  border-top: none;
+  border-left: none;
+  border-right: 2px solid #26a69a;
+  border-bottom: none;
+  -webkit-transform: rotate(90deg);
+          transform: rotate(90deg);
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden;
+  -webkit-transform-origin: 100% 100%;
+          transform-origin: 100% 100%;
+}
+
+[type="checkbox"]:indeterminate:disabled + span:not(.lever):before {
+  border-right: 2px solid rgba(0, 0, 0, 0.42);
+  background-color: transparent;
+}
+
+[type="checkbox"].filled-in + span:not(.lever):after {
+  border-radius: 2px;
+}
+
+[type="checkbox"].filled-in + span:not(.lever):before,
+[type="checkbox"].filled-in + span:not(.lever):after {
+  content: '';
+  left: 0;
+  position: absolute;
+  /* .1s delay is for check animation */
+  -webkit-transition: border .25s, background-color .25s, width .20s .1s, height .20s .1s, top .20s .1s, left .20s .1s;
+  transition: border .25s, background-color .25s, width .20s .1s, height .20s .1s, top .20s .1s, left .20s .1s;
+  z-index: 1;
+}
+
+[type="checkbox"].filled-in:not(:checked) + span:not(.lever):before {
+  width: 0;
+  height: 0;
+  border: 3px solid transparent;
+  left: 6px;
+  top: 10px;
+  -webkit-transform: rotateZ(37deg);
+          transform: rotateZ(37deg);
+  -webkit-transform-origin: 100% 100%;
+          transform-origin: 100% 100%;
+}
+
+[type="checkbox"].filled-in:not(:checked) + span:not(.lever):after {
+  height: 20px;
+  width: 20px;
+  background-color: transparent;
+  border: 2px solid #5a5a5a;
+  top: 0px;
+  z-index: 0;
+}
+
+[type="checkbox"].filled-in:checked + span:not(.lever):before {
+  top: 0;
+  left: 1px;
+  width: 8px;
+  height: 13px;
+  border-top: 2px solid transparent;
+  border-left: 2px solid transparent;
+  border-right: 2px solid #fff;
+  border-bottom: 2px solid #fff;
+  -webkit-transform: rotateZ(37deg);
+          transform: rotateZ(37deg);
+  -webkit-transform-origin: 100% 100%;
+          transform-origin: 100% 100%;
+}
+
+[type="checkbox"].filled-in:checked + span:not(.lever):after {
+  top: 0;
+  width: 20px;
+  height: 20px;
+  border: 2px solid #26a69a;
+  background-color: #26a69a;
+  z-index: 0;
+}
+
+[type="checkbox"].filled-in.tabbed:focus + span:not(.lever):after {
+  border-radius: 2px;
+  border-color: #5a5a5a;
+  background-color: rgba(0, 0, 0, 0.1);
+}
+
+[type="checkbox"].filled-in.tabbed:checked:focus + span:not(.lever):after {
+  border-radius: 2px;
+  background-color: #26a69a;
+  border-color: #26a69a;
+}
+
+[type="checkbox"].filled-in:disabled:not(:checked) + span:not(.lever):before {
+  background-color: transparent;
+  border: 2px solid transparent;
+}
+
+[type="checkbox"].filled-in:disabled:not(:checked) + span:not(.lever):after {
+  border-color: transparent;
+  background-color: #949494;
+}
+
+[type="checkbox"].filled-in:disabled:checked + span:not(.lever):before {
+  background-color: transparent;
+}
+
+[type="checkbox"].filled-in:disabled:checked + span:not(.lever):after {
+  background-color: #949494;
+  border-color: #949494;
+}
+
+/* Switch
+   ========================================================================== */
+.switch,
+.switch * {
+  -webkit-tap-highlight-color: transparent;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none;
+}
+
+.switch label {
+  cursor: pointer;
+}
+
+.switch label input[type=checkbox] {
+  opacity: 0;
+  width: 0;
+  height: 0;
+}
+
+.switch label input[type=checkbox]:checked + .lever {
+  background-color: #84c7c1;
+}
+
+.switch label input[type=checkbox]:checked + .lever:before, .switch label input[type=checkbox]:checked + .lever:after {
+  left: 18px;
+}
+
+.switch label input[type=checkbox]:checked + .lever:after {
+  background-color: #26a69a;
+}
+
+.switch label .lever {
+  content: "";
+  display: inline-block;
+  position: relative;
+  width: 36px;
+  height: 14px;
+  background-color: rgba(0, 0, 0, 0.38);
+  border-radius: 15px;
+  margin-right: 10px;
+  -webkit-transition: background 0.3s ease;
+  transition: background 0.3s ease;
+  vertical-align: middle;
+  margin: 0 16px;
+}
+
+.switch label .lever:before, .switch label .lever:after {
+  content: "";
+  position: absolute;
+  display: inline-block;
+  width: 20px;
+  height: 20px;
+  border-radius: 50%;
+  left: 0;
+  top: -3px;
+  -webkit-transition: left 0.3s ease, background .3s ease, -webkit-box-shadow 0.1s ease, -webkit-transform .1s ease;
+  transition: left 0.3s ease, background .3s ease, -webkit-box-shadow 0.1s ease, -webkit-transform .1s ease;
+  transition: left 0.3s ease, background .3s ease, box-shadow 0.1s ease, transform .1s ease;
+  transition: left 0.3s ease, background .3s ease, box-shadow 0.1s ease, transform .1s ease, -webkit-box-shadow 0.1s ease, -webkit-transform .1s ease;
+}
+
+.switch label .lever:before {
+  background-color: rgba(38, 166, 154, 0.15);
+}
+
+.switch label .lever:after {
+  background-color: #F1F1F1;
+  -webkit-box-shadow: 0px 3px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12);
+          box-shadow: 0px 3px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12);
+}
+
+input[type=checkbox]:checked:not(:disabled) ~ .lever:active::before,
+input[type=checkbox]:checked:not(:disabled).tabbed:focus ~ .lever::before {
+  -webkit-transform: scale(2.4);
+          transform: scale(2.4);
+  background-color: rgba(38, 166, 154, 0.15);
+}
+
+input[type=checkbox]:not(:disabled) ~ .lever:active:before,
+input[type=checkbox]:not(:disabled).tabbed:focus ~ .lever::before {
+  -webkit-transform: scale(2.4);
+          transform: scale(2.4);
+  background-color: rgba(0, 0, 0, 0.08);
+}
+
+.switch input[type=checkbox][disabled] + .lever {
+  cursor: default;
+  background-color: rgba(0, 0, 0, 0.12);
+}
+
+.switch label input[type=checkbox][disabled] + .lever:after,
+.switch label input[type=checkbox][disabled]:checked + .lever:after {
+  background-color: #949494;
+}
+
+/* Select Field
+   ========================================================================== */
+select {
+  display: none;
+}
+
+select.browser-default {
+  display: block;
+}
+
+select {
+  background-color: rgba(255, 255, 255, 0.9);
+  width: 100%;
+  padding: 5px;
+  border: 1px solid #f2f2f2;
+  border-radius: 2px;
+  height: 3rem;
+}
+
+.select-label {
+  position: absolute;
+}
+
+.select-wrapper {
+  position: relative;
+}
+
+.select-wrapper.valid + label,
+.select-wrapper.invalid + label {
+  width: 100%;
+  pointer-events: none;
+}
+
+.select-wrapper input.select-dropdown {
+  position: relative;
+  cursor: pointer;
+  background-color: transparent;
+  border: none;
+  border-bottom: 1px solid #9e9e9e;
+  outline: none;
+  height: 3rem;
+  line-height: 3rem;
+  width: 100%;
+  font-size: 16px;
+  margin: 0 0 8px 0;
+  padding: 0;
+  display: block;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none;
+  z-index: 1;
+}
+
+.select-wrapper input.select-dropdown:focus {
+  border-bottom: 1px solid #26a69a;
+}
+
+.select-wrapper .caret {
+  position: absolute;
+  right: 0;
+  top: 0;
+  bottom: 0;
+  margin: auto 0;
+  z-index: 0;
+  fill: rgba(0, 0, 0, 0.87);
+}
+
+.select-wrapper + label {
+  position: absolute;
+  top: -26px;
+  font-size: 0.8rem;
+}
+
+select:disabled {
+  color: rgba(0, 0, 0, 0.42);
+}
+
+.select-wrapper.disabled + label {
+  color: rgba(0, 0, 0, 0.42);
+}
+
+.select-wrapper.disabled .caret {
+  fill: rgba(0, 0, 0, 0.42);
+}
+
+.select-wrapper input.select-dropdown:disabled {
+  color: rgba(0, 0, 0, 0.42);
+  cursor: default;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none;
+}
+
+.select-wrapper i {
+  color: rgba(0, 0, 0, 0.3);
+}
+
+.select-dropdown li.disabled,
+.select-dropdown li.disabled > span,
+.select-dropdown li.optgroup {
+  color: rgba(0, 0, 0, 0.3);
+  background-color: transparent;
+}
+
+body.keyboard-focused .select-dropdown.dropdown-content li:focus {
+  background-color: rgba(0, 0, 0, 0.08);
+}
+
+.select-dropdown.dropdown-content li:hover {
+  background-color: rgba(0, 0, 0, 0.08);
+}
+
+.select-dropdown.dropdown-content li.selected {
+  background-color: rgba(0, 0, 0, 0.03);
+}
+
+.prefix ~ .select-wrapper {
+  margin-left: 3rem;
+  width: 92%;
+  width: calc(100% - 3rem);
+}
+
+.prefix ~ label {
+  margin-left: 3rem;
+}
+
+.select-dropdown li img {
+  height: 40px;
+  width: 40px;
+  margin: 5px 15px;
+  float: right;
+}
+
+.select-dropdown li.optgroup {
+  border-top: 1px solid #eee;
+}
+
+.select-dropdown li.optgroup.selected > span {
+  color: rgba(0, 0, 0, 0.7);
+}
+
+.select-dropdown li.optgroup > span {
+  color: rgba(0, 0, 0, 0.4);
+}
+
+.select-dropdown li.optgroup ~ li.optgroup-option {
+  padding-left: 1rem;
+}
+
+/* File Input
+   ========================================================================== */
+.file-field {
+  position: relative;
+}
+
+.file-field .file-path-wrapper {
+  overflow: hidden;
+  padding-left: 10px;
+}
+
+.file-field input.file-path {
+  width: 100%;
+}
+
+.file-field .btn, .file-field .btn-large, .file-field .btn-small {
+  float: left;
+  height: 3rem;
+  line-height: 3rem;
+}
+
+.file-field span {
+  cursor: pointer;
+}
+
+.file-field input[type=file] {
+  position: absolute;
+  top: 0;
+  right: 0;
+  left: 0;
+  bottom: 0;
+  width: 100%;
+  margin: 0;
+  padding: 0;
+  font-size: 20px;
+  cursor: pointer;
+  opacity: 0;
+  filter: alpha(opacity=0);
+}
+
+.file-field input[type=file]::-webkit-file-upload-button {
+  display: none;
+}
+
+/* Range
+   ========================================================================== */
+.range-field {
+  position: relative;
+}
+
+input[type=range],
+input[type=range] + .thumb {
+  cursor: pointer;
+}
+
+input[type=range] {
+  position: relative;
+  background-color: transparent;
+  border: none;
+  outline: none;
+  width: 100%;
+  margin: 15px 0;
+  padding: 0;
+}
+
+input[type=range]:focus {
+  outline: none;
+}
+
+input[type=range] + .thumb {
+  position: absolute;
+  top: 10px;
+  left: 0;
+  border: none;
+  height: 0;
+  width: 0;
+  border-radius: 50%;
+  background-color: #26a69a;
+  margin-left: 7px;
+  -webkit-transform-origin: 50% 50%;
+          transform-origin: 50% 50%;
+  -webkit-transform: rotate(-45deg);
+          transform: rotate(-45deg);
+}
+
+input[type=range] + .thumb .value {
+  display: block;
+  width: 30px;
+  text-align: center;
+  color: #26a69a;
+  font-size: 0;
+  -webkit-transform: rotate(45deg);
+          transform: rotate(45deg);
+}
+
+input[type=range] + .thumb.active {
+  border-radius: 50% 50% 50% 0;
+}
+
+input[type=range] + .thumb.active .value {
+  color: #fff;
+  margin-left: -1px;
+  margin-top: 8px;
+  font-size: 10px;
+}
+
+input[type=range] {
+  -webkit-appearance: none;
+}
+
+input[type=range]::-webkit-slider-runnable-track {
+  height: 3px;
+  background: #c2c0c2;
+  border: none;
+}
+
+input[type=range]::-webkit-slider-thumb {
+  border: none;
+  height: 14px;
+  width: 14px;
+  border-radius: 50%;
+  background: #26a69a;
+  -webkit-transition: -webkit-box-shadow .3s;
+  transition: -webkit-box-shadow .3s;
+  transition: box-shadow .3s;
+  transition: box-shadow .3s, -webkit-box-shadow .3s;
+  -webkit-appearance: none;
+  background-color: #26a69a;
+  -webkit-transform-origin: 50% 50%;
+          transform-origin: 50% 50%;
+  margin: -5px 0 0 0;
+}
+
+.keyboard-focused input[type=range]:focus:not(.active)::-webkit-slider-thumb {
+  -webkit-box-shadow: 0 0 0 10px rgba(38, 166, 154, 0.26);
+          box-shadow: 0 0 0 10px rgba(38, 166, 154, 0.26);
+}
+
+input[type=range] {
+  /* fix for FF unable to apply focus style bug  */
+  border: 1px solid white;
+  /*required for proper track sizing in FF*/
+}
+
+input[type=range]::-moz-range-track {
+  height: 3px;
+  background: #c2c0c2;
+  border: none;
+}
+
+input[type=range]::-moz-focus-inner {
+  border: 0;
+}
+
+input[type=range]::-moz-range-thumb {
+  border: none;
+  height: 14px;
+  width: 14px;
+  border-radius: 50%;
+  background: #26a69a;
+  -webkit-transition: -webkit-box-shadow .3s;
+  transition: -webkit-box-shadow .3s;
+  transition: box-shadow .3s;
+  transition: box-shadow .3s, -webkit-box-shadow .3s;
+  margin-top: -5px;
+}
+
+input[type=range]:-moz-focusring {
+  outline: 1px solid #fff;
+  outline-offset: -1px;
+}
+
+.keyboard-focused input[type=range]:focus:not(.active)::-moz-range-thumb {
+  box-shadow: 0 0 0 10px rgba(38, 166, 154, 0.26);
+}
+
+input[type=range]::-ms-track {
+  height: 3px;
+  background: transparent;
+  border-color: transparent;
+  border-width: 6px 0;
+  /*remove default tick marks*/
+  color: transparent;
+}
+
+input[type=range]::-ms-fill-lower {
+  background: #777;
+}
+
+input[type=range]::-ms-fill-upper {
+  background: #ddd;
+}
+
+input[type=range]::-ms-thumb {
+  border: none;
+  height: 14px;
+  width: 14px;
+  border-radius: 50%;
+  background: #26a69a;
+  -webkit-transition: -webkit-box-shadow .3s;
+  transition: -webkit-box-shadow .3s;
+  transition: box-shadow .3s;
+  transition: box-shadow .3s, -webkit-box-shadow .3s;
+}
+
+.keyboard-focused input[type=range]:focus:not(.active)::-ms-thumb {
+  box-shadow: 0 0 0 10px rgba(38, 166, 154, 0.26);
+}
+
+/***************
+    Nav List
+***************/
+.table-of-contents.fixed {
+  position: fixed;
+}
+
+.table-of-contents li {
+  padding: 2px 0;
+}
+
+.table-of-contents a {
+  display: inline-block;
+  font-weight: 300;
+  color: #757575;
+  padding-left: 16px;
+  height: 1.5rem;
+  line-height: 1.5rem;
+  letter-spacing: .4;
+  display: inline-block;
+}
+
+.table-of-contents a:hover {
+  color: #a8a8a8;
+  padding-left: 15px;
+  border-left: 1px solid #ee6e73;
+}
+
+.table-of-contents a.active {
+  font-weight: 500;
+  padding-left: 14px;
+  border-left: 2px solid #ee6e73;
+}
+
+.sidenav {
+  position: fixed;
+  width: 300px;
+  left: 0;
+  top: 0;
+  margin: 0;
+  -webkit-transform: translateX(-100%);
+          transform: translateX(-100%);
+  height: 100%;
+  height: calc(100% + 60px);
+  height: -moz-calc(100%);
+  padding-bottom: 60px;
+  background-color: #fff;
+  z-index: 999;
+  overflow-y: auto;
+  will-change: transform;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden;
+  -webkit-transform: translateX(-105%);
+          transform: translateX(-105%);
+}
+
+.sidenav.right-aligned {
+  right: 0;
+  -webkit-transform: translateX(105%);
+          transform: translateX(105%);
+  left: auto;
+  -webkit-transform: translateX(100%);
+          transform: translateX(100%);
+}
+
+.sidenav .collapsible {
+  margin: 0;
+}
+
+.sidenav li {
+  float: none;
+  line-height: 48px;
+}
+
+.sidenav li.active {
+  background-color: rgba(0, 0, 0, 0.05);
+}
+
+.sidenav li > a {
+  color: rgba(0, 0, 0, 0.87);
+  display: block;
+  font-size: 14px;
+  font-weight: 500;
+  height: 48px;
+  line-height: 48px;
+  padding: 0 32px;
+}
+
+.sidenav li > a:hover {
+  background-color: rgba(0, 0, 0, 0.05);
+}
+
+.sidenav li > a.btn, .sidenav li > a.btn-large, .sidenav li > a.btn-small, .sidenav li > a.btn-large, .sidenav li > a.btn-flat, .sidenav li > a.btn-floating {
+  margin: 10px 15px;
+}
+
+.sidenav li > a.btn, .sidenav li > a.btn-large, .sidenav li > a.btn-small, .sidenav li > a.btn-large, .sidenav li > a.btn-floating {
+  color: #fff;
+}
+
+.sidenav li > a.btn-flat {
+  color: #343434;
+}
+
+.sidenav li > a.btn:hover, .sidenav li > a.btn-large:hover, .sidenav li > a.btn-small:hover, .sidenav li > a.btn-large:hover {
+  background-color: #2bbbad;
+}
+
+.sidenav li > a.btn-floating:hover {
+  background-color: #26a69a;
+}
+
+.sidenav li > a > i,
+.sidenav li > a > [class^="mdi-"], .sidenav li > a li > a > [class*="mdi-"],
+.sidenav li > a > i.material-icons {
+  float: left;
+  height: 48px;
+  line-height: 48px;
+  margin: 0 32px 0 0;
+  width: 24px;
+  color: rgba(0, 0, 0, 0.54);
+}
+
+.sidenav .divider {
+  margin: 8px 0 0 0;
+}
+
+.sidenav .subheader {
+  cursor: initial;
+  pointer-events: none;
+  color: rgba(0, 0, 0, 0.54);
+  font-size: 14px;
+  font-weight: 500;
+  line-height: 48px;
+}
+
+.sidenav .subheader:hover {
+  background-color: transparent;
+}
+
+.sidenav .user-view {
+  position: relative;
+  padding: 32px 32px 0;
+  margin-bottom: 8px;
+}
+
+.sidenav .user-view > a {
+  height: auto;
+  padding: 0;
+}
+
+.sidenav .user-view > a:hover {
+  background-color: transparent;
+}
+
+.sidenav .user-view .background {
+  overflow: hidden;
+  position: absolute;
+  top: 0;
+  right: 0;
+  bottom: 0;
+  left: 0;
+  z-index: -1;
+}
+
+.sidenav .user-view .circle, .sidenav .user-view .name, .sidenav .user-view .email {
+  display: block;
+}
+
+.sidenav .user-view .circle {
+  height: 64px;
+  width: 64px;
+}
+
+.sidenav .user-view .name,
+.sidenav .user-view .email {
+  font-size: 14px;
+  line-height: 24px;
+}
+
+.sidenav .user-view .name {
+  margin-top: 16px;
+  font-weight: 500;
+}
+
+.sidenav .user-view .email {
+  padding-bottom: 16px;
+  font-weight: 400;
+}
+
+.drag-target {
+  height: 100%;
+  width: 10px;
+  position: fixed;
+  top: 0;
+  z-index: 998;
+}
+
+.drag-target.right-aligned {
+  right: 0;
+}
+
+.sidenav.sidenav-fixed {
+  left: 0;
+  -webkit-transform: translateX(0);
+          transform: translateX(0);
+  position: fixed;
+}
+
+.sidenav.sidenav-fixed.right-aligned {
+  right: 0;
+  left: auto;
+}
+
+@media only screen and (max-width: 992px) {
+  .sidenav.sidenav-fixed {
+    -webkit-transform: translateX(-105%);
+            transform: translateX(-105%);
+  }
+  .sidenav.sidenav-fixed.right-aligned {
+    -webkit-transform: translateX(105%);
+            transform: translateX(105%);
+  }
+  .sidenav > a {
+    padding: 0 16px;
+  }
+  .sidenav .user-view {
+    padding: 16px 16px 0;
+  }
+}
+
+.sidenav .collapsible-body > ul:not(.collapsible) > li.active,
+.sidenav.sidenav-fixed .collapsible-body > ul:not(.collapsible) > li.active {
+  background-color: #ee6e73;
+}
+
+.sidenav .collapsible-body > ul:not(.collapsible) > li.active a,
+.sidenav.sidenav-fixed .collapsible-body > ul:not(.collapsible) > li.active a {
+  color: #fff;
+}
+
+.sidenav .collapsible-body {
+  padding: 0;
+}
+
+.sidenav-overlay {
+  position: fixed;
+  top: 0;
+  left: 0;
+  right: 0;
+  opacity: 0;
+  height: 120vh;
+  background-color: rgba(0, 0, 0, 0.5);
+  z-index: 997;
+  display: none;
+}
+
+/*
+    @license
+    Copyright (c) 2014 The Polymer Project Authors. All rights reserved.
+    This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
+    The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
+    The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
+    Code distributed by Google as part of the polymer project is also
+    subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
+ */
+/**************************/
+/* STYLES FOR THE SPINNER */
+/**************************/
+/*
+ * Constants:
+ *      STROKEWIDTH = 3px
+ *      ARCSIZE     = 270 degrees (amount of circle the arc takes up)
+ *      ARCTIME     = 1333ms (time it takes to expand and contract arc)
+ *      ARCSTARTROT = 216 degrees (how much the start location of the arc
+ *                                should rotate each time, 216 gives us a
+ *                                5 pointed star shape (it's 360/5 * 3).
+ *                                For a 7 pointed star, we might do
+ *                                360/7 * 3 = 154.286)
+ *      CONTAINERWIDTH = 28px
+ *      SHRINK_TIME = 400ms
+ */
+.preloader-wrapper {
+  display: inline-block;
+  position: relative;
+  width: 50px;
+  height: 50px;
+}
+
+.preloader-wrapper.small {
+  width: 36px;
+  height: 36px;
+}
+
+.preloader-wrapper.big {
+  width: 64px;
+  height: 64px;
+}
+
+.preloader-wrapper.active {
+  /* duration: 360 * ARCTIME / (ARCSTARTROT + (360-ARCSIZE)) */
+  -webkit-animation: container-rotate 1568ms linear infinite;
+  animation: container-rotate 1568ms linear infinite;
+}
+
+@-webkit-keyframes container-rotate {
+  to {
+    -webkit-transform: rotate(360deg);
+  }
+}
+
+@keyframes container-rotate {
+  to {
+    -webkit-transform: rotate(360deg);
+            transform: rotate(360deg);
+  }
+}
+
+.spinner-layer {
+  position: absolute;
+  width: 100%;
+  height: 100%;
+  opacity: 0;
+  border-color: #26a69a;
+}
+
+.spinner-blue,
+.spinner-blue-only {
+  border-color: #4285f4;
+}
+
+.spinner-red,
+.spinner-red-only {
+  border-color: #db4437;
+}
+
+.spinner-yellow,
+.spinner-yellow-only {
+  border-color: #f4b400;
+}
+
+.spinner-green,
+.spinner-green-only {
+  border-color: #0f9d58;
+}
+
+/**
+ * IMPORTANT NOTE ABOUT CSS ANIMATION PROPERTIES (keanulee):
+ *
+ * iOS Safari (tested on iOS 8.1) does not handle animation-delay very well - it doesn't
+ * guarantee that the animation will start _exactly_ after that value. So we avoid using
+ * animation-delay and instead set custom keyframes for each color (as redundant as it
+ * seems).
+ *
+ * We write out each animation in full (instead of separating animation-name,
+ * animation-duration, etc.) because under the polyfill, Safari does not recognize those
+ * specific properties properly, treats them as -webkit-animation, and overrides the
+ * other animation rules. See https://github.com/Polymer/platform/issues/53.
+ */
+.active .spinner-layer.spinner-blue {
+  /* durations: 4 * ARCTIME */
+  -webkit-animation: fill-unfill-rotate 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both, blue-fade-in-out 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both;
+  animation: fill-unfill-rotate 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both, blue-fade-in-out 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both;
+}
+
+.active .spinner-layer.spinner-red {
+  /* durations: 4 * ARCTIME */
+  -webkit-animation: fill-unfill-rotate 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both, red-fade-in-out 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both;
+  animation: fill-unfill-rotate 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both, red-fade-in-out 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both;
+}
+
+.active .spinner-layer.spinner-yellow {
+  /* durations: 4 * ARCTIME */
+  -webkit-animation: fill-unfill-rotate 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both, yellow-fade-in-out 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both;
+  animation: fill-unfill-rotate 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both, yellow-fade-in-out 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both;
+}
+
+.active .spinner-layer.spinner-green {
+  /* durations: 4 * ARCTIME */
+  -webkit-animation: fill-unfill-rotate 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both, green-fade-in-out 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both;
+  animation: fill-unfill-rotate 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both, green-fade-in-out 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both;
+}
+
+.active .spinner-layer,
+.active .spinner-layer.spinner-blue-only,
+.active .spinner-layer.spinner-red-only,
+.active .spinner-layer.spinner-yellow-only,
+.active .spinner-layer.spinner-green-only {
+  /* durations: 4 * ARCTIME */
+  opacity: 1;
+  -webkit-animation: fill-unfill-rotate 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both;
+  animation: fill-unfill-rotate 5332ms cubic-bezier(0.4, 0, 0.2, 1) infinite both;
+}
+
+@-webkit-keyframes fill-unfill-rotate {
+  12.5% {
+    -webkit-transform: rotate(135deg);
+  }
+  /* 0.5 * ARCSIZE */
+  25% {
+    -webkit-transform: rotate(270deg);
+  }
+  /* 1   * ARCSIZE */
+  37.5% {
+    -webkit-transform: rotate(405deg);
+  }
+  /* 1.5 * ARCSIZE */
+  50% {
+    -webkit-transform: rotate(540deg);
+  }
+  /* 2   * ARCSIZE */
+  62.5% {
+    -webkit-transform: rotate(675deg);
+  }
+  /* 2.5 * ARCSIZE */
+  75% {
+    -webkit-transform: rotate(810deg);
+  }
+  /* 3   * ARCSIZE */
+  87.5% {
+    -webkit-transform: rotate(945deg);
+  }
+  /* 3.5 * ARCSIZE */
+  to {
+    -webkit-transform: rotate(1080deg);
+  }
+  /* 4   * ARCSIZE */
+}
+
+@keyframes fill-unfill-rotate {
+  12.5% {
+    -webkit-transform: rotate(135deg);
+            transform: rotate(135deg);
+  }
+  /* 0.5 * ARCSIZE */
+  25% {
+    -webkit-transform: rotate(270deg);
+            transform: rotate(270deg);
+  }
+  /* 1   * ARCSIZE */
+  37.5% {
+    -webkit-transform: rotate(405deg);
+            transform: rotate(405deg);
+  }
+  /* 1.5 * ARCSIZE */
+  50% {
+    -webkit-transform: rotate(540deg);
+            transform: rotate(540deg);
+  }
+  /* 2   * ARCSIZE */
+  62.5% {
+    -webkit-transform: rotate(675deg);
+            transform: rotate(675deg);
+  }
+  /* 2.5 * ARCSIZE */
+  75% {
+    -webkit-transform: rotate(810deg);
+            transform: rotate(810deg);
+  }
+  /* 3   * ARCSIZE */
+  87.5% {
+    -webkit-transform: rotate(945deg);
+            transform: rotate(945deg);
+  }
+  /* 3.5 * ARCSIZE */
+  to {
+    -webkit-transform: rotate(1080deg);
+            transform: rotate(1080deg);
+  }
+  /* 4   * ARCSIZE */
+}
+
+@-webkit-keyframes blue-fade-in-out {
+  from {
+    opacity: 1;
+  }
+  25% {
+    opacity: 1;
+  }
+  26% {
+    opacity: 0;
+  }
+  89% {
+    opacity: 0;
+  }
+  90% {
+    opacity: 1;
+  }
+  100% {
+    opacity: 1;
+  }
+}
+
+@keyframes blue-fade-in-out {
+  from {
+    opacity: 1;
+  }
+  25% {
+    opacity: 1;
+  }
+  26% {
+    opacity: 0;
+  }
+  89% {
+    opacity: 0;
+  }
+  90% {
+    opacity: 1;
+  }
+  100% {
+    opacity: 1;
+  }
+}
+
+@-webkit-keyframes red-fade-in-out {
+  from {
+    opacity: 0;
+  }
+  15% {
+    opacity: 0;
+  }
+  25% {
+    opacity: 1;
+  }
+  50% {
+    opacity: 1;
+  }
+  51% {
+    opacity: 0;
+  }
+}
+
+@keyframes red-fade-in-out {
+  from {
+    opacity: 0;
+  }
+  15% {
+    opacity: 0;
+  }
+  25% {
+    opacity: 1;
+  }
+  50% {
+    opacity: 1;
+  }
+  51% {
+    opacity: 0;
+  }
+}
+
+@-webkit-keyframes yellow-fade-in-out {
+  from {
+    opacity: 0;
+  }
+  40% {
+    opacity: 0;
+  }
+  50% {
+    opacity: 1;
+  }
+  75% {
+    opacity: 1;
+  }
+  76% {
+    opacity: 0;
+  }
+}
+
+@keyframes yellow-fade-in-out {
+  from {
+    opacity: 0;
+  }
+  40% {
+    opacity: 0;
+  }
+  50% {
+    opacity: 1;
+  }
+  75% {
+    opacity: 1;
+  }
+  76% {
+    opacity: 0;
+  }
+}
+
+@-webkit-keyframes green-fade-in-out {
+  from {
+    opacity: 0;
+  }
+  65% {
+    opacity: 0;
+  }
+  75% {
+    opacity: 1;
+  }
+  90% {
+    opacity: 1;
+  }
+  100% {
+    opacity: 0;
+  }
+}
+
+@keyframes green-fade-in-out {
+  from {
+    opacity: 0;
+  }
+  65% {
+    opacity: 0;
+  }
+  75% {
+    opacity: 1;
+  }
+  90% {
+    opacity: 1;
+  }
+  100% {
+    opacity: 0;
+  }
+}
+
+/**
+ * Patch the gap that appear between the two adjacent div.circle-clipper while the
+ * spinner is rotating (appears on Chrome 38, Safari 7.1, and IE 11).
+ */
+.gap-patch {
+  position: absolute;
+  top: 0;
+  left: 45%;
+  width: 10%;
+  height: 100%;
+  overflow: hidden;
+  border-color: inherit;
+}
+
+.gap-patch .circle {
+  width: 1000%;
+  left: -450%;
+}
+
+.circle-clipper {
+  display: inline-block;
+  position: relative;
+  width: 50%;
+  height: 100%;
+  overflow: hidden;
+  border-color: inherit;
+}
+
+.circle-clipper .circle {
+  width: 200%;
+  height: 100%;
+  border-width: 3px;
+  /* STROKEWIDTH */
+  border-style: solid;
+  border-color: inherit;
+  border-bottom-color: transparent !important;
+  border-radius: 50%;
+  -webkit-animation: none;
+  animation: none;
+  position: absolute;
+  top: 0;
+  right: 0;
+  bottom: 0;
+}
+
+.circle-clipper.left .circle {
+  left: 0;
+  border-right-color: transparent !important;
+  -webkit-transform: rotate(129deg);
+  transform: rotate(129deg);
+}
+
+.circle-clipper.right .circle {
+  left: -100%;
+  border-left-color: transparent !important;
+  -webkit-transform: rotate(-129deg);
+  transform: rotate(-129deg);
+}
+
+.active .circle-clipper.left .circle {
+  /* duration: ARCTIME */
+  -webkit-animation: left-spin 1333ms cubic-bezier(0.4, 0, 0.2, 1) infinite both;
+  animation: left-spin 1333ms cubic-bezier(0.4, 0, 0.2, 1) infinite both;
+}
+
+.active .circle-clipper.right .circle {
+  /* duration: ARCTIME */
+  -webkit-animation: right-spin 1333ms cubic-bezier(0.4, 0, 0.2, 1) infinite both;
+  animation: right-spin 1333ms cubic-bezier(0.4, 0, 0.2, 1) infinite both;
+}
+
+@-webkit-keyframes left-spin {
+  from {
+    -webkit-transform: rotate(130deg);
+  }
+  50% {
+    -webkit-transform: rotate(-5deg);
+  }
+  to {
+    -webkit-transform: rotate(130deg);
+  }
+}
+
+@keyframes left-spin {
+  from {
+    -webkit-transform: rotate(130deg);
+            transform: rotate(130deg);
+  }
+  50% {
+    -webkit-transform: rotate(-5deg);
+            transform: rotate(-5deg);
+  }
+  to {
+    -webkit-transform: rotate(130deg);
+            transform: rotate(130deg);
+  }
+}
+
+@-webkit-keyframes right-spin {
+  from {
+    -webkit-transform: rotate(-130deg);
+  }
+  50% {
+    -webkit-transform: rotate(5deg);
+  }
+  to {
+    -webkit-transform: rotate(-130deg);
+  }
+}
+
+@keyframes right-spin {
+  from {
+    -webkit-transform: rotate(-130deg);
+            transform: rotate(-130deg);
+  }
+  50% {
+    -webkit-transform: rotate(5deg);
+            transform: rotate(5deg);
+  }
+  to {
+    -webkit-transform: rotate(-130deg);
+            transform: rotate(-130deg);
+  }
+}
+
+#spinnerContainer.cooldown {
+  /* duration: SHRINK_TIME */
+  -webkit-animation: container-rotate 1568ms linear infinite, fade-out 400ms cubic-bezier(0.4, 0, 0.2, 1);
+  animation: container-rotate 1568ms linear infinite, fade-out 400ms cubic-bezier(0.4, 0, 0.2, 1);
+}
+
+@-webkit-keyframes fade-out {
+  from {
+    opacity: 1;
+  }
+  to {
+    opacity: 0;
+  }
+}
+
+@keyframes fade-out {
+  from {
+    opacity: 1;
+  }
+  to {
+    opacity: 0;
+  }
+}
+
+.slider {
+  position: relative;
+  height: 400px;
+  width: 100%;
+}
+
+.slider.fullscreen {
+  height: 100%;
+  width: 100%;
+  position: absolute;
+  top: 0;
+  left: 0;
+  right: 0;
+  bottom: 0;
+}
+
+.slider.fullscreen ul.slides {
+  height: 100%;
+}
+
+.slider.fullscreen ul.indicators {
+  z-index: 2;
+  bottom: 30px;
+}
+
+.slider .slides {
+  background-color: #9e9e9e;
+  margin: 0;
+  height: 400px;
+}
+
+.slider .slides li {
+  opacity: 0;
+  position: absolute;
+  top: 0;
+  left: 0;
+  z-index: 1;
+  width: 100%;
+  height: inherit;
+  overflow: hidden;
+}
+
+.slider .slides li img {
+  height: 100%;
+  width: 100%;
+  background-size: cover;
+  background-position: center;
+}
+
+.slider .slides li .caption {
+  color: #fff;
+  position: absolute;
+  top: 15%;
+  left: 15%;
+  width: 70%;
+  opacity: 0;
+}
+
+.slider .slides li .caption p {
+  color: #e0e0e0;
+}
+
+.slider .slides li.active {
+  z-index: 2;
+}
+
+.slider .indicators {
+  position: absolute;
+  text-align: center;
+  left: 0;
+  right: 0;
+  bottom: 0;
+  margin: 0;
+}
+
+.slider .indicators .indicator-item {
+  display: inline-block;
+  position: relative;
+  cursor: pointer;
+  height: 16px;
+  width: 16px;
+  margin: 0 12px;
+  background-color: #e0e0e0;
+  -webkit-transition: background-color .3s;
+  transition: background-color .3s;
+  border-radius: 50%;
+}
+
+.slider .indicators .indicator-item.active {
+  background-color: #4CAF50;
+}
+
+.carousel {
+  overflow: hidden;
+  position: relative;
+  width: 100%;
+  height: 400px;
+  -webkit-perspective: 500px;
+          perspective: 500px;
+  -webkit-transform-style: preserve-3d;
+          transform-style: preserve-3d;
+  -webkit-transform-origin: 0% 50%;
+          transform-origin: 0% 50%;
+}
+
+.carousel.carousel-slider {
+  top: 0;
+  left: 0;
+}
+
+.carousel.carousel-slider .carousel-fixed-item {
+  position: absolute;
+  left: 0;
+  right: 0;
+  bottom: 20px;
+  z-index: 1;
+}
+
+.carousel.carousel-slider .carousel-fixed-item.with-indicators {
+  bottom: 68px;
+}
+
+.carousel.carousel-slider .carousel-item {
+  width: 100%;
+  height: 100%;
+  min-height: 400px;
+  position: absolute;
+  top: 0;
+  left: 0;
+}
+
+.carousel.carousel-slider .carousel-item h2 {
+  font-size: 24px;
+  font-weight: 500;
+  line-height: 32px;
+}
+
+.carousel.carousel-slider .carousel-item p {
+  font-size: 15px;
+}
+
+.carousel .carousel-item {
+  visibility: hidden;
+  width: 200px;
+  height: 200px;
+  position: absolute;
+  top: 0;
+  left: 0;
+}
+
+.carousel .carousel-item > img {
+  width: 100%;
+}
+
+.carousel .indicators {
+  position: absolute;
+  text-align: center;
+  left: 0;
+  right: 0;
+  bottom: 0;
+  margin: 0;
+}
+
+.carousel .indicators .indicator-item {
+  display: inline-block;
+  position: relative;
+  cursor: pointer;
+  height: 8px;
+  width: 8px;
+  margin: 24px 4px;
+  background-color: rgba(255, 255, 255, 0.5);
+  -webkit-transition: background-color .3s;
+  transition: background-color .3s;
+  border-radius: 50%;
+}
+
+.carousel .indicators .indicator-item.active {
+  background-color: #fff;
+}
+
+.carousel.scrolling .carousel-item .materialboxed,
+.carousel .carousel-item:not(.active) .materialboxed {
+  pointer-events: none;
+}
+
+.tap-target-wrapper {
+  width: 800px;
+  height: 800px;
+  position: fixed;
+  z-index: 1000;
+  visibility: hidden;
+  -webkit-transition: visibility 0s .3s;
+  transition: visibility 0s .3s;
+}
+
+.tap-target-wrapper.open {
+  visibility: visible;
+  -webkit-transition: visibility 0s;
+  transition: visibility 0s;
+}
+
+.tap-target-wrapper.open .tap-target {
+  -webkit-transform: scale(1);
+          transform: scale(1);
+  opacity: .95;
+  -webkit-transition: opacity 0.3s cubic-bezier(0.42, 0, 0.58, 1), -webkit-transform 0.3s cubic-bezier(0.42, 0, 0.58, 1);
+  transition: opacity 0.3s cubic-bezier(0.42, 0, 0.58, 1), -webkit-transform 0.3s cubic-bezier(0.42, 0, 0.58, 1);
+  transition: transform 0.3s cubic-bezier(0.42, 0, 0.58, 1), opacity 0.3s cubic-bezier(0.42, 0, 0.58, 1);
+  transition: transform 0.3s cubic-bezier(0.42, 0, 0.58, 1), opacity 0.3s cubic-bezier(0.42, 0, 0.58, 1), -webkit-transform 0.3s cubic-bezier(0.42, 0, 0.58, 1);
+}
+
+.tap-target-wrapper.open .tap-target-wave::before {
+  -webkit-transform: scale(1);
+          transform: scale(1);
+}
+
+.tap-target-wrapper.open .tap-target-wave::after {
+  visibility: visible;
+  -webkit-animation: pulse-animation 1s cubic-bezier(0.24, 0, 0.38, 1) infinite;
+          animation: pulse-animation 1s cubic-bezier(0.24, 0, 0.38, 1) infinite;
+  -webkit-transition: opacity .3s,
+ visibility 0s 1s,
+ -webkit-transform .3s;
+  transition: opacity .3s,
+ visibility 0s 1s,
+ -webkit-transform .3s;
+  transition: opacity .3s,
+ transform .3s,
+ visibility 0s 1s;
+  transition: opacity .3s,
+ transform .3s,
+ visibility 0s 1s,
+ -webkit-transform .3s;
+}
+
+.tap-target {
+  position: absolute;
+  font-size: 1rem;
+  border-radius: 50%;
+  background-color: #ee6e73;
+  -webkit-box-shadow: 0 20px 20px 0 rgba(0, 0, 0, 0.14), 0 10px 50px 0 rgba(0, 0, 0, 0.12), 0 30px 10px -20px rgba(0, 0, 0, 0.2);
+          box-shadow: 0 20px 20px 0 rgba(0, 0, 0, 0.14), 0 10px 50px 0 rgba(0, 0, 0, 0.12), 0 30px 10px -20px rgba(0, 0, 0, 0.2);
+  width: 100%;
+  height: 100%;
+  opacity: 0;
+  -webkit-transform: scale(0);
+          transform: scale(0);
+  -webkit-transition: opacity 0.3s cubic-bezier(0.42, 0, 0.58, 1), -webkit-transform 0.3s cubic-bezier(0.42, 0, 0.58, 1);
+  transition: opacity 0.3s cubic-bezier(0.42, 0, 0.58, 1), -webkit-transform 0.3s cubic-bezier(0.42, 0, 0.58, 1);
+  transition: transform 0.3s cubic-bezier(0.42, 0, 0.58, 1), opacity 0.3s cubic-bezier(0.42, 0, 0.58, 1);
+  transition: transform 0.3s cubic-bezier(0.42, 0, 0.58, 1), opacity 0.3s cubic-bezier(0.42, 0, 0.58, 1), -webkit-transform 0.3s cubic-bezier(0.42, 0, 0.58, 1);
+}
+
+.tap-target-content {
+  position: relative;
+  display: table-cell;
+}
+
+.tap-target-wave {
+  position: absolute;
+  border-radius: 50%;
+  z-index: 10001;
+}
+
+.tap-target-wave::before, .tap-target-wave::after {
+  content: '';
+  display: block;
+  position: absolute;
+  width: 100%;
+  height: 100%;
+  border-radius: 50%;
+  background-color: #ffffff;
+}
+
+.tap-target-wave::before {
+  -webkit-transform: scale(0);
+          transform: scale(0);
+  -webkit-transition: -webkit-transform .3s;
+  transition: -webkit-transform .3s;
+  transition: transform .3s;
+  transition: transform .3s, -webkit-transform .3s;
+}
+
+.tap-target-wave::after {
+  visibility: hidden;
+  -webkit-transition: opacity .3s,
+ visibility 0s,
+ -webkit-transform .3s;
+  transition: opacity .3s,
+ visibility 0s,
+ -webkit-transform .3s;
+  transition: opacity .3s,
+ transform .3s,
+ visibility 0s;
+  transition: opacity .3s,
+ transform .3s,
+ visibility 0s,
+ -webkit-transform .3s;
+  z-index: -1;
+}
+
+.tap-target-origin {
+  top: 50%;
+  left: 50%;
+  -webkit-transform: translate(-50%, -50%);
+          transform: translate(-50%, -50%);
+  z-index: 10002;
+  position: absolute !important;
+}
+
+.tap-target-origin:not(.btn):not(.btn-large):not(.btn-small), .tap-target-origin:not(.btn):not(.btn-large):not(.btn-small):hover {
+  background: none;
+}
+
+@media only screen and (max-width: 600px) {
+  .tap-target, .tap-target-wrapper {
+    width: 600px;
+    height: 600px;
+  }
+}
+
+.pulse {
+  overflow: visible;
+  position: relative;
+}
+
+.pulse::before {
+  content: '';
+  display: block;
+  position: absolute;
+  width: 100%;
+  height: 100%;
+  top: 0;
+  left: 0;
+  background-color: inherit;
+  border-radius: inherit;
+  -webkit-transition: opacity .3s, -webkit-transform .3s;
+  transition: opacity .3s, -webkit-transform .3s;
+  transition: opacity .3s, transform .3s;
+  transition: opacity .3s, transform .3s, -webkit-transform .3s;
+  -webkit-animation: pulse-animation 1s cubic-bezier(0.24, 0, 0.38, 1) infinite;
+          animation: pulse-animation 1s cubic-bezier(0.24, 0, 0.38, 1) infinite;
+  z-index: -1;
+}
+
+@-webkit-keyframes pulse-animation {
+  0% {
+    opacity: 1;
+    -webkit-transform: scale(1);
+            transform: scale(1);
+  }
+  50% {
+    opacity: 0;
+    -webkit-transform: scale(1.5);
+            transform: scale(1.5);
+  }
+  100% {
+    opacity: 0;
+    -webkit-transform: scale(1.5);
+            transform: scale(1.5);
+  }
+}
+
+@keyframes pulse-animation {
+  0% {
+    opacity: 1;
+    -webkit-transform: scale(1);
+            transform: scale(1);
+  }
+  50% {
+    opacity: 0;
+    -webkit-transform: scale(1.5);
+            transform: scale(1.5);
+  }
+  100% {
+    opacity: 0;
+    -webkit-transform: scale(1.5);
+            transform: scale(1.5);
+  }
+}
+
+/* Modal */
+.datepicker-modal {
+  max-width: 325px;
+  min-width: 300px;
+  max-height: none;
+}
+
+.datepicker-container.modal-content {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-orient: vertical;
+  -webkit-box-direction: normal;
+  -webkit-flex-direction: column;
+      -ms-flex-direction: column;
+          flex-direction: column;
+  padding: 0;
+}
+
+.datepicker-controls {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-pack: justify;
+  -webkit-justify-content: space-between;
+      -ms-flex-pack: justify;
+          justify-content: space-between;
+  width: 280px;
+  margin: 0 auto;
+}
+
+.datepicker-controls .selects-container {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+}
+
+.datepicker-controls .select-wrapper input {
+  border-bottom: none;
+  text-align: center;
+  margin: 0;
+}
+
+.datepicker-controls .select-wrapper input:focus {
+  border-bottom: none;
+}
+
+.datepicker-controls .select-wrapper .caret {
+  display: none;
+}
+
+.datepicker-controls .select-year input {
+  width: 50px;
+}
+
+.datepicker-controls .select-month input {
+  width: 70px;
+}
+
+.month-prev, .month-next {
+  margin-top: 4px;
+  cursor: pointer;
+  background-color: transparent;
+  border: none;
+}
+
+/* Date Display */
+.datepicker-date-display {
+  -webkit-box-flex: 1;
+  -webkit-flex: 1 auto;
+      -ms-flex: 1 auto;
+          flex: 1 auto;
+  background-color: #26a69a;
+  color: #fff;
+  padding: 20px 22px;
+  font-weight: 500;
+}
+
+.datepicker-date-display .year-text {
+  display: block;
+  font-size: 1.5rem;
+  line-height: 25px;
+  color: rgba(255, 255, 255, 0.7);
+}
+
+.datepicker-date-display .date-text {
+  display: block;
+  font-size: 2.8rem;
+  line-height: 47px;
+  font-weight: 500;
+}
+
+/* Calendar */
+.datepicker-calendar-container {
+  -webkit-box-flex: 2.5;
+  -webkit-flex: 2.5 auto;
+      -ms-flex: 2.5 auto;
+          flex: 2.5 auto;
+}
+
+.datepicker-table {
+  width: 280px;
+  font-size: 1rem;
+  margin: 0 auto;
+}
+
+.datepicker-table thead {
+  border-bottom: none;
+}
+
+.datepicker-table th {
+  padding: 10px 5px;
+  text-align: center;
+}
+
+.datepicker-table tr {
+  border: none;
+}
+
+.datepicker-table abbr {
+  text-decoration: none;
+  color: #999;
+}
+
+.datepicker-table td {
+  border-radius: 50%;
+  padding: 0;
+}
+
+.datepicker-table td.is-today {
+  color: #26a69a;
+}
+
+.datepicker-table td.is-selected {
+  background-color: #26a69a;
+  color: #fff;
+}
+
+.datepicker-table td.is-outside-current-month, .datepicker-table td.is-disabled {
+  color: rgba(0, 0, 0, 0.3);
+  pointer-events: none;
+}
+
+.datepicker-day-button {
+  background-color: transparent;
+  border: none;
+  line-height: 38px;
+  display: block;
+  width: 100%;
+  border-radius: 50%;
+  padding: 0 5px;
+  cursor: pointer;
+  color: inherit;
+}
+
+.datepicker-day-button:focus {
+  background-color: rgba(43, 161, 150, 0.25);
+}
+
+/* Footer */
+.datepicker-footer {
+  width: 280px;
+  margin: 0 auto;
+  padding-bottom: 5px;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-pack: justify;
+  -webkit-justify-content: space-between;
+      -ms-flex-pack: justify;
+          justify-content: space-between;
+}
+
+.datepicker-cancel,
+.datepicker-clear,
+.datepicker-today,
+.datepicker-done {
+  color: #26a69a;
+  padding: 0 1rem;
+}
+
+.datepicker-clear {
+  color: #F44336;
+}
+
+/* Media Queries */
+@media only screen and (min-width: 601px) {
+  .datepicker-modal {
+    max-width: 625px;
+  }
+  .datepicker-container.modal-content {
+    -webkit-box-orient: horizontal;
+    -webkit-box-direction: normal;
+    -webkit-flex-direction: row;
+        -ms-flex-direction: row;
+            flex-direction: row;
+  }
+  .datepicker-date-display {
+    -webkit-box-flex: 0;
+    -webkit-flex: 0 1 270px;
+        -ms-flex: 0 1 270px;
+            flex: 0 1 270px;
+  }
+  .datepicker-controls,
+  .datepicker-table,
+  .datepicker-footer {
+    width: 320px;
+  }
+  .datepicker-day-button {
+    line-height: 44px;
+  }
+}
+
+/* Timepicker Containers */
+.timepicker-modal {
+  max-width: 325px;
+  max-height: none;
+}
+
+.timepicker-container.modal-content {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-orient: vertical;
+  -webkit-box-direction: normal;
+  -webkit-flex-direction: column;
+      -ms-flex-direction: column;
+          flex-direction: column;
+  padding: 0;
+}
+
+.text-primary {
+  color: white;
+}
+
+/* Clock Digital Display */
+.timepicker-digital-display {
+  -webkit-box-flex: 1;
+  -webkit-flex: 1 auto;
+      -ms-flex: 1 auto;
+          flex: 1 auto;
+  background-color: #26a69a;
+  padding: 10px;
+  font-weight: 300;
+}
+
+.timepicker-text-container {
+  font-size: 4rem;
+  font-weight: bold;
+  text-align: center;
+  color: rgba(255, 255, 255, 0.6);
+  font-weight: 400;
+  position: relative;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none;
+}
+
+.timepicker-span-hours,
+.timepicker-span-minutes,
+.timepicker-span-am-pm div {
+  cursor: pointer;
+}
+
+.timepicker-span-hours {
+  margin-right: 3px;
+}
+
+.timepicker-span-minutes {
+  margin-left: 3px;
+}
+
+.timepicker-display-am-pm {
+  font-size: 1.3rem;
+  position: absolute;
+  right: 1rem;
+  bottom: 1rem;
+  font-weight: 400;
+}
+
+/* Analog Clock Display */
+.timepicker-analog-display {
+  -webkit-box-flex: 2.5;
+  -webkit-flex: 2.5 auto;
+      -ms-flex: 2.5 auto;
+          flex: 2.5 auto;
+}
+
+.timepicker-plate {
+  background-color: #eee;
+  border-radius: 50%;
+  width: 270px;
+  height: 270px;
+  overflow: visible;
+  position: relative;
+  margin: auto;
+  margin-top: 25px;
+  margin-bottom: 5px;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none;
+}
+
+.timepicker-canvas,
+.timepicker-dial {
+  position: absolute;
+  left: 0;
+  right: 0;
+  top: 0;
+  bottom: 0;
+}
+
+.timepicker-minutes {
+  visibility: hidden;
+}
+
+.timepicker-tick {
+  border-radius: 50%;
+  color: rgba(0, 0, 0, 0.87);
+  line-height: 40px;
+  text-align: center;
+  width: 40px;
+  height: 40px;
+  position: absolute;
+  cursor: pointer;
+  font-size: 15px;
+}
+
+.timepicker-tick.active,
+.timepicker-tick:hover {
+  background-color: rgba(38, 166, 154, 0.25);
+}
+
+.timepicker-dial {
+  -webkit-transition: opacity 350ms, -webkit-transform 350ms;
+  transition: opacity 350ms, -webkit-transform 350ms;
+  transition: transform 350ms, opacity 350ms;
+  transition: transform 350ms, opacity 350ms, -webkit-transform 350ms;
+}
+
+.timepicker-dial-out {
+  opacity: 0;
+}
+
+.timepicker-dial-out.timepicker-hours {
+  -webkit-transform: scale(1.1, 1.1);
+          transform: scale(1.1, 1.1);
+}
+
+.timepicker-dial-out.timepicker-minutes {
+  -webkit-transform: scale(0.8, 0.8);
+          transform: scale(0.8, 0.8);
+}
+
+.timepicker-canvas {
+  -webkit-transition: opacity 175ms;
+  transition: opacity 175ms;
+}
+
+.timepicker-canvas line {
+  stroke: #26a69a;
+  stroke-width: 4;
+  stroke-linecap: round;
+}
+
+.timepicker-canvas-out {
+  opacity: 0.25;
+}
+
+.timepicker-canvas-bearing {
+  stroke: none;
+  fill: #26a69a;
+}
+
+.timepicker-canvas-bg {
+  stroke: none;
+  fill: #26a69a;
+}
+
+/* Footer */
+.timepicker-footer {
+  margin: 0 auto;
+  padding: 5px 1rem;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-pack: justify;
+  -webkit-justify-content: space-between;
+      -ms-flex-pack: justify;
+          justify-content: space-between;
+}
+
+.timepicker-clear {
+  color: #F44336;
+}
+
+.timepicker-close {
+  color: #26a69a;
+}
+
+.timepicker-clear,
+.timepicker-close {
+  padding: 0 20px;
+}
+
+/* Media Queries */
+@media only screen and (min-width: 601px) {
+  .timepicker-modal {
+    max-width: 600px;
+  }
+  .timepicker-container.modal-content {
+    -webkit-box-orient: horizontal;
+    -webkit-box-direction: normal;
+    -webkit-flex-direction: row;
+        -ms-flex-direction: row;
+            flex-direction: row;
+  }
+  .timepicker-text-container {
+    top: 32%;
+  }
+  .timepicker-display-am-pm {
+    position: relative;
+    right: auto;
+    bottom: auto;
+    text-align: center;
+    margin-top: 1.2rem;
+  }
+}
diff --git a/css/style.css b/css/style.css
new file mode 100644
index 0000000..303f503
--- /dev/null
+++ b/css/style.css
@@ -0,0 +1,10 @@
+
+.td-input {
+    padding: 0;
+  }
+  
+.td-input input[type="text"]:not(.browser-default) {
+    margin: 0;
+    background-repeat: no-repeat;
+    background-position: right center;
+}
\ No newline at end of file
diff --git a/fonts/flUhRq6tzZclQEJ-Vdg-IuiaDsNc.woff2 b/fonts/flUhRq6tzZclQEJ-Vdg-IuiaDsNc.woff2
new file mode 100644
index 0000000000000000000000000000000000000000..28fc9e48d600b3b63d289184e75d30c5243656cb
GIT binary patch
literal 110560
zcmV)CK*GOwPew8T0RR910k7Zy4*&oF1hvcn0k4Gs0RR9100000000000000000000
z0000Q92*cEgQY?SU;xc}2m}!b3XYW&ir`KQy#xROHUcCAo<;;91%i49AY1#plSTaY
z$nKeLV1p>&r*nu&;sgM+O1EFDMmBe-oY^%jJ;_`vWN|?Cn!~u;0ei*2IyL+M|NsC0
zRmtQT+waEnwvC4f8lb9bm1X^3LNUc965HB&(psU|x_4!r8>~@#Sr3vq$`-?M13P(<
zX~u5Z9|Edka5R-vNtJB;GO3fP#uM`3=16yQbP0FG-4&kG1A}szweiI5xD9A!(zsRG
z_{!!B-0*JJzxHpCnL{RI!o|TI+`)a442Y<i?@exap)9eP;iG07>?9vTaUi4^nE3Qw
z&vOeteqyKPC?8F~%Fa7Uzp7lxkIlW6c&cpl{E|KJuxQ7l;hHXeb&2nkkN|gy2$P5<
zFv1`Q<?$w)0obGyr_73#^QO}dTj;G{|AaiG78}_7r@;3X;wiDZHSh{`WzXf?@+?1<
zt9o1B%8gIC!7TGm&DT&LT)BVprm+E47XOcq#9yR5NH+S@oyAO?ffQq)=_aId#@`lN
z7Q3oHk1OvKV^F1;W@eh1A!+6=M_L$CIHkdcviNe|%P861x)>l2G0h9)-zlfH^aISX
zgOEw-tGsFt1N7L~rD`<DARbb7FUdnblhC5E-_PB<nZ+fFc_UPslw^r2-a465pXl;c
z?}tnJy>4_j3@`y2Ae14Sracw==5}IV_4JGQGqa;L|IN?M><%vHT|Tg`GF1qw3Q<-O
zfMQSticv8E#HKY1gj9@*U69(Vhz`Ix*D}56C1@=`xX=&$-2Tsv-p20T?gb`;ZS;mp
zh04g@Fi`42n;6(&gOR9+@0m}(;!C5@4@QEKufz<jr~MrD9|wc~wu8pgJoHdA30yST
zfP)VvQ#SM{5&eGX-uo}eI*t@r2H}7ekd2H^+6vXWjIXeDrn(M)o=>;_R1mssN%LOY
zbjfSF(A=B0K$`+>X>J!<nwBo`?(4#m0;SLwWbMMH?~WoA+|Wrn6qSP8m={N!5k|+N
ziK31`9sN!cXZ*%x9m*$+Gdg~q86N+zHZ11<4netK5H!dbOJiwAu$=9IU(m3Z5-Ncz
z?6sbX?jd%F?Hy9d!#|<ffG3E}eS_qK*pSv!Nsxj1Rdleot07COA-vSKZFosV7vgK#
zzHc3Gz~%BulPyA0HM>I$#`anCo&y<Tc_hN8^n<lI|L(rYL7YTHL_{PSqID?E%gMo_
z3ops+17ks{&kfC8IhMv7&hT0U<zNJRO2xlfpW=#p+(#9*sB+aIRgtz%QKw23QtfdL
zgZ~<arwsDqzeHX{yk@q}I%npGVQ%<@EAAy8c`k^UZZL)_cfFmJUGHq^zyG(r_ImAU
ztso*2LJ$!V5fKp)5#JJ#khlI^=l+}dwR<Ub#Z^~cU#B#i<|p}x$RHvjBH~XE5fK^O
zkWvH;&%3RMV}Z&CKC+gm|Kl9RM?n#E^D)Ot#e{~Hqj3dIt*)*ime#(y5^uHdvQC>f
zq<LcVdv&`ysq1!k7yoOsN`FIXH~W$bcG+?@EFD3HC~$Wrwl(jRq%-MEYOaO_Q&lz0
zu*Y6N$nL;tMM|fR0g~*iZVF;hK<(R4X7&4NbkyzxzEF`+cfPP?D%zd!&Nqo-;0?^P
zg#I>Jw+L)!yCs9J;vh&|A7n(?R?7w)N+SqCV>~F7I(@>a>XG*n%r284<3P2x01xQ*
zE&p!-a=x7QRn>i~>fB^I(9HprWC(#J&v5g^PQm1RW_LUOi7r?B>RbyXt6{;Csqt-+
z1{#KjMS#!PFAvCwGtLs0c$3cGyb{Uk+UQI%7?fYwgeTljufU$bwu*3@C1*P~r>7(!
zCV7SXqxsjZ|B^Oo@4Z1rRuKDUPs=p}X3xwzUz#>)p^X?Y5=V5v$L&Rma(!R(jrV->
z5&%IA2gAXnm-Hm9w41+vNYS+`*LLfw_QAWfud43dy}K&uFmZ<ShSgHS0|B=>urR~!
zc7bjExUD4m`IUavzvMWXWWW?>U||TB1|G2O-g~>81*>e8oxfhywE4sWL{mJot&I`w
zbzHRLez}?Mf&jsC?${FlU#-1=>o2ReErUnK8;KzP;=G7gbpgEr`X{~Fc5k~+c1X-f
zMxG#1-pn8`0zLyJUz{X={!7*BiXttWloRMMPo7QEM5(Qvl_%U~PmHIzZb;{Sul}zp
zpz0TjMEyd6K!Kn@fTRI12vq<jph!y04Z_^sB1EZa+0#!}CrO<sbyBCdU{O>9Amsr;
z(JfK7N5S%hkSMj>(c9zn`q>lh*^uM0FUP%H<7tn(*FD|mxW_%7_qfNk@71z$8!Ky9
zbA;lmKCSGL{&1G3q+?Az{D<7a#|MIi1^cF}(TM9R6k><d(<?>&kKzUj-Fwm9<Xn{E
zL;+P~u$x@%owvK@Nip8>3~%EsZJ6hucZPkIai%W~*T4V2O#R$;frRp$p=QRm<Q3%{
zw-lXMYcFHheW~lcdR6FG-3V3P2;BffH$Vc_04X&{{(e=}P*tI&1ArVK0Mz)9lx9qY
zZ!=8PpL0wB;tx=!CWobW-uaw~N%E}hyqv|>D=)oR+NA{=JWTdz_CMFoI6Oia+Dt$Y
zM{>%HNIiXQ37Z@M&9+Pm|JkyCas8CnlEptD%&(?uj&@pii~Zoy_#uZ36WVs{SpyO>
zvk7AMqqSe&^u>r7YC0WULZY<4^Tyc2EF?mTz|;2C`*W15S*GtMK?aegs1zb1jWnI)
ztzXM#Fs4z5QZ&(BbRdX8=z6VuuX_^y>y8cXczgf<KQpJIqN<`IA|m2!&+ngJ=j`r%
z&H3EtF)AWPjT%)osv;ty>iS*p_x#K3^S+tSd*9JYDG?(^L_~|$N-1S2?Ji>(F1&TC
zw>$zOpi-nA#$5l;(Rtmpb-POw6cm&xOX{yVFLVC?!OlV3=<`}+L}W?`BOzmvH~t?&
zxBCCMV7cwG8Wa!$p$SMr>Lk-@Cei;kKrllS0WOA_=C;_u_I<aMxrSH?0_q3fU>A1S
z=4^NekjxDDsiSG9o1v|H$Luc2yfvu)3;EKW-DHG6*zbuyJnIQhu87Bph!9+HJnMV)
z#_~F2O|7Ewt>(c6tCy~|VXHIxvg~K}1sv*gW$GGl{FmD=FCzsP*x(>evY#Uy>m=tm
z-zBbdhlf1gs={o-IC?mP1(ARRBvUJOFagT|9g8*HG0QX@;h1EW4}!6BK`>O-1bt;i
z&{dWMZDm2wROSSAWkyg{&TA;mpIIFhWMCKe;|TjY$WhgQo;t3+*Kl6LaSi)5Yyxja
z+y`l*roz$&_Tm7}ae^~k)@pA}H~~v0{$Yr(MI6Cy3~FT?#N(DE7iB)}IrBIZ?|hTm
zJnhq%YY7kxfsNY>((vTs?74<wWGBw3p>y1Y;I%v!x^yKBKG6iz!D->iQA_r3pXiXg
z5Ltb~x7`oR6BU4AVi%5bR2^WxEAa}kraqJXldmPgfB=Z3ksf|C5|FKxE?Xj&brteq
zDD7@H+|^)}zO%Y3vuaqm_dhf0Bbp9P12d)~xhDFkceW8!`sTQca+z+D9Zc$8IWoU_
zY;I+EbG}aA_1W7U+!O$KF<@ad6l+*9jfzU?vyiBYn1Y@JLd(jT8eDsD@}h~srE_*l
zlN6q#U~;jfogTGs?67TVx}jsn&;NPYi@n^##&sJG*l^K>8_!=mdj9Z}v23>7X{46i
zx~6CvbZ%r7EZ3+j=n<Hh#5o9dP}swWhm*XgU?HxJ7JE=x!6Xb0Bt}?mAkh;+Jjgg&
zu#dmo^G=JWQAiR^Efe-=H$?0x;^i6F#kF=?%uij^_4KwlxF~(EmTNoR78?sKoj+2c
zi)HDQoa_fDu$bCSFwWGbclb5gMr`aCQVfhF!`y}_x~7EcSyakVGL=shbfdA9&dMxi
z&uZTy1Pt%r4U!jmd0N*v@K+?UX_ySja&i)@CFr%ja9q*Q68Zb?2J0Nt*LUic5rly-
zG{ZKP)YNa)pQh1j`G;Kb4Od)t8aj$tknzTtpHp3UBSI6l6@FD)jh%tG9tr*)gO6ay
zL(zB*d0i18G0Ve`x6fGM))+p}Y8iJ68D5J$3J>7oj&g=uV+AD$FlQf7RHgWlLaCj5
z<8y&2=L6i$#1N9B?mL0ee{YtDje}k^0DJUTYe^oWtwj$Kh-S9h`;$jh+1ib#*b86k
zAy@DD?W3-Or98YqcDXBU+@!2p-bvB48CcmBGBR_Y)B@m8I9!xYeWakV+6&TJ;AfQ=
zs3O4D)fIUMp`)Xo<Z(G2F5eAv)`o|NL@aSRX++z5qCkMaTw6!7$A{De=fB;s0*j=P
zNqxq!5}zs+d|dR7bRkfn%K+3ob@Ya*;Qej;EMW!C;v*6t5&|MASa=f??Tr<oX+){)
zo{Ek!S9s0M;%3n=j0VgU&RjZUZWQMYYNeS`ncJR`;nE0C{ESC{P2Pkie3Y>{E5fPd
zmDFjF1u8nYR<KtXG*Fh46>D_)xi~V;JZ>h6L<Ky&HD_%WFspAF46}L~b0qE!i|%uG
z#qY4H6qygn<<g6%hT#@BcQ%I+Wx{D(hJa^CK)J~tYdg5!Ji!e?FJx#qnkm!BU+IR*
zD9wZ13LllQu+8-hh2CMGwH<VQHxqu4UCAjx+b*d^T3vJ;Ox}cDU2&Q?8n)vn0*MT(
zynC0jY2!feyB$IcCKJK<3b94#&56I?aqf69ge_^$Uy;8lEh5w09@mP*MiL-7=K8yi
z(=f-6l8|CTx}7n1o(j4(!^_P{ddj?Fg*W{f@{JKr5Qxt}?0Pc0F}}8?XA9YMg4Lo=
zY}+mCDhrVYdBC%h0r9#azO=PVr)XVV{;rqv`_Oi(q?AD#YC^T&LJXMId}iGjx7fD?
z_mp<6YdTfYJEJgfckh$ZC8?7E>+jF<s>wUEPLXlR0+N@<b-e$Ebi+GLm~Eli&p$z(
z0?E2Vb<!)m8p{?VMF%~ejrR{(YcPsBcW0GiS^3Qy4D_d}4h|x5epyHi@K8E~i&-T9
zX^6kSV`E7SyyQ13l;ApDSk6isn-s3XTEvS@bL0MWknkS~<j6JE2qtvbSyzCdOwt)6
z;o_+-2+LZL%J+%)TS3GgVhZVPo<!CR{y<Y`W4AjMT1aBWJUp>-hFrlQQmpzQzj|tM
zq6vzd@d1M9pE3p@vbvQFrf%FX;)(~G@~Jp}zj(868|*wP26i9)Yi+@II4e_~_09L0
zw$P)mOFa1l?VSN{y$_^QV#M;naIvs8R1Gr#^(CuevTQKf`Y<w(0^gP5;f)MXSvd?i
zvU_l_rSLi-d5<YwFUb`_)a0)Ua7=F}rfj)V=&|<Ek<G<709+x(7pB>Np@@+`57lI9
zx;g&D;4gU>A|cKH?_TP8pNhHTR-kCUGZOd)A>duWr&rjdf?cVVSSC`91$CpXj82a%
zuAW|AeS8A*@#)t;_v*usKl9>iKaT(ic%JYmoMuWRA|Wp*F0Tt|6)AZuGh6qrrZ!G?
z;kC$WFgATeQmW9u3uT+q$`tD&P;2M3aiu9ewAxn#8RHi|5k9=Wjz^(BuxBi#CQeGN
z9s7}#gJC2FDdkz5YC`|%3%Igi+Y6d>GSb=9ch<paTIuV%^nZ5MQ<JYCE>Y&IsFL~j
zge(Q!5`oKkicm~~j<cFzvg1jyr2eH8C^#}n4l-)F<|LH+mI@ZM1w+dP#2cQjuSPHj
zf8ScJaaQJ8ga^R$sl)x}Q-%A^rwsR=PZ91ppFG?hXUVg%cnNg0kynzWi+EV{C=V#*
zQ9`BC@!9Dl<ZmhlmHApwk)TCOB*v-)GyqL@CzTy1eh|cuim!0&&}UJ+mN#4#juQ{s
zH@TxCZnETFBaVoxlf%%p)$!s4*DVN~!+~j6qGQC)0!Lm)3nxdvV{-?3xDTynTdq0c
zwl?BKOAlc>%-xzq^$!P>4v_n8$cL?I)I>}LrhTE6eVM`Zdqid7WxhYqk~AP*TfK-&
z)sN16(aF?D4|@o6YV|S%59<tA_-??gQzFO2b)d5^f5{-_E*l$;K?YpT|7k60zT+w$
zYy19h5=p_j@`PJm*<)J(Uwfzi7ng9XbwqFy(h7wzR`M(-yBsf!F9Hp4VFEYDq9kW~
zaT_I5&LEtYhNE=tmnlQXiScznf)^e>6TP(&c;FiD086aAhK%p#n8A_B9jvwxrDYc;
z41sI$h`G@iHL&0%ZB1h^-_>2Cbf7*LfeXn0&{XO>YGML$hu88Z{!KCNCa25MV~~RW
zH0@sumTfzoV)>`lj=|@vE(lurKayiacW+D#Qp>Ado{p=IeE+CK99`U21+iK*`nTml
zmuk#8{*}NL*ZQ4@r95!^b*5XoUUj+X{k(ez@DYEg0!ygT4QbHY!iO2+xQGIbKa39+
z(f)MXJp?L_lJ4;lwirDy!s7of^5T`=+>auo^bENv_MZVr)?lVocqNKd)C<fw@0BX7
zYho>(o(aUVz2$=~=-bJ}mP3<EoVzKXhu56H!-X46Igm{R22P=-p~Vu_ltZi;<mc*&
zh%2ix^Q1dW&dWV}Zyj;}Z|7!sPQqex7ao_h@<rEPUHke@wcQxGbVJ6?IAW&ZlSYl3
zxEpI0tlYGC<?bxq8WXp8{OplSw|xB8E`QV4`^<+w6L~GQF~Ci|wgK7=-&)P<@o)@*
z3WNp*zFL%u)QAiqmdU50daYc^bVwC(NpjkLs)wxz!M1K%?>pe&Uot9{<4OB4eN(2E
zG%Axl>E+q#v)KRe0BRQ_$m-r5#0`2_+mT#wq2epSs-9eim#ktu4=<*DCR1<U)`XWq
z;}HoXElcOrJT5==K#CUjAcGM2fz$+NDo|`k;VLAG=7=YjVag8qu}=zkR(4BKM+hru
z-AAY_Kdb8PvJGcPWkhPPt=nt*?)HDdTC>@BH^(?taZ*=fAyv$L<E<}L_)r6C&CGZx
zm9iBNj3GzQ-`0Y-HLTU4sM8)V!F0lNEHbTcWFP?=hk|vM;ILk8_bQ3&vFfu@aJpo^
zPw;)($0;lYdz$(&265ryXQQ{!bxzWq(8#lc>NQ6KC{N5xyN+X>fR5T&$z_5?GaSqH
zJM06+8iZL=7zRh>sq3r+eRmWT?2~l*jG|BrJGttc86^I18Ol`+r5Oy7Z!Z%n^r+LQ
zTrb2PfWxNc36xM#rQUV~j=yoFkr#`cK7M6r_2K&@m*`j!khUbv(?<F%*Aj)&6q%iN
zg0vzc(P14umqqo-smj<s#1XTyXmBVvHeZ=|mI#JgzENPs#~x~lM2a!GXUWpWMn}#3
zKNiOGmuiuc(g|t|1%)03<_HTDP=GbNLk2_|d7v=-SOt@wyuK=NS>{wW4-?ImDUcyT
z^3!1rG6hgjQ+K!h@eUzS^h*ze6iKG}5~SttMW0J`y`v#-Cv;CwdnsyiF`&3e@RrQY
zY@J}11#|8WP_r@-2)LuBPiJm`X#7kpC?OO3d=$oM8Ocx4v#E6?va&gI)>n#yk)=@N
z%q;3tW4cCppub4-B#YwPO;iR2>B0-CI-23HT^(7C(IyU5zs2Z-I@P~>NeD0lP)4kL
zY0GqX1W|&a$oi~fWHsnCU&53+2E%CY(5v@tLC3RO?}8#$)>=Np#6$K`0cZJVgyA*s
z6(Yk({ZLv5p<SC!+K^}aLTxD2)XcRoj<3>X2_ewt%;{#oj8e9q0idXKZ2WP>EYcER
zSEz+Kw)V+s{1{RcZSgV!mOz)%_|ymAG;wo(AFup^7J&N6yh#bY(;L;P)ikf;ikJp%
zyYIx%3irka?%o~^CD{K{LlLJ^>OO^AA%=3Opg6iNq%T-t59DZwY2m?9-UDVf;)+a>
z62Yty^b`S*=x)=}rI-5Cfq|Z|qLF`vaQ`fel%EQ2?yhdw$O52k2aehhy3d<K=7C97
z96vGHom(Zpp#s~rIeIGqD`V-4S9^(IJZv3n5;eOK!`@JqYb#xx!16shKXIE*!f@xS
zP_MBXfzmE@^>{?vjsSORAGl^4)nC+dQF9bjjGIoin%zZjT^KhAcv`OPBTeO8E{y8M
z`_I-4Q*C2TNm)(D8VlcLQPX7ON3y6X0k9r!j{#ViniDX2IzbdM_U**eMh7f)3$4|j
z<n0FBawr;G&Rs1f9>MIVQc~e5*Kvl_3&x&|0UiRx<v8YwZ#@z0jd9X%h7_pC$_Ody
z0BhJ7$FKzDIOy%_Lm=N2ojM&nz^Rx5iAt5bqcD;ozx5w*rFNw1;k0po?DFv+J^T-q
z>rUR^m*N`NSY(p~1LuxNbjL`rk?Wjw?uh>4|LdWnNUpgiUs=5w-GiNPnBQ(2i+6P9
zh6~p{d*#$kszg%|3QC~Q8d1HRq?$n1Q`JsxtbAkVyUf+QL<NP#r3A$#2fI{KUDndN
zwreAn<KSG5o88DMQ;i#1XvWPJt=_}3-B`Q1Zm}g;W5NR*2GRd!xhnuAcDhX@^Fe*#
zO!G$$^taB`HJ!=ql;0f8&O}#dbxCdDl+`n~nPM4cA)JMIKrVk0S~_d&4l`KwjLZ~s
z%3pB#@I_By%*F23txqL;+-Jtaqu)j467huxAd@vkin{xDJ|#fZ%TJ+cQl`xM_Y@7|
zg^DrXb@H#DIwx6@;HOYS>7L~%(U|TNcNopFGtbInab0MIQ%yscdwgi8Q(+OEx2%(S
zqD(+^)O1Q1fY&j~ohVm>@b+AfIhtEYS?&{KKBaFCucLc1$mh3ILDVj9*;s(X6PL%E
zllRD!Jjt-&PXS9GEx~Lc8x5|RuHpb1b~U%a*hTk}gVsOEZ3#-+Zwgbib4MP+|D(7j
zVW)tbPEqUH1M0f`MLoN!KQx@1?5aKShNET9NhyTsVu|uIh$eq3|Kcl74goivAxlCx
zUdklGI}^&2GrFD?395DdY(z&}+?5{3M~J@HJaN4RctF9avDWgADz4{C9D|f(J(bHs
zMa|dI3Y4+KPv7A)xkWb_n=vp+`dCJHbzG;7H2R7*R0!1G%O`D(O6m`kUD<T$H5sVn
zWloTGb|+lLr0&Z3>~AkrhTHJ;E0*(0wD>_lg;1^2`xetA=>Yj_$YxG`iFU<FB!QpG
z5G=jnUaL%;3DbL^CFTan#H+F{ChW*1)*<1@t=aVk6Ki2&io=61NmRi9V##yg>y`lA
z^BlrSEb0Wc3|?p@5zL}(>J=d>;R|Z>I2x_Tsu)Rx6HqRWpsuQk;I3}kD5NQc7F80|
zl4X0+5sT~A#L9}5DWQ&UqEf>?jf|nvaF!`3rrIf~eojPFj2ZlC;tb6Y4BC7JRB>Ek
z3$q+`DvI(Z#mIzC)^^?*)?V40s@)~JQ>H-tDbM0u;3sUJi>_q(uov=Q0&@oa$R7l~
z-NOqOq9kmgjt=k8fUO5_91!nFZirRmM|C6;JYa!4l!wCGCyK$8=Fw$|<iixQmq_2_
z&GpuwP4>hHXbah7$C~DG@g-yd4n|T)890DObYro;VtZGFE?pZ%Oo{fWO%ywwZySW~
z%~K73KZp}t<uR}NTzvBZ$T^NHIDrx?M>X@Sqs~cU@J$<M<eLu13X!%NY-eJAY<X;c
z)$*;}^6?92MbVwyxY5kBRzR@<K~f{hP&~DG*_1n})K5V<6&`1yy~2@(r9t_vjTVO6
zx}plB0S)PG-OklqfDY^Px%21YBkb4C!iN%dJ*iF}^aF(UM=ipojf)TT0gCriypI;n
zj5g1p5iqGKLhhcYU=Y&qS52D&j`VUj4c!Q_Syp`-TF9S`S~zkA;a#y?8W_$irj5UJ
z$TqQJ%@T)CVHN<B97E3p49J@%Ps@QGo#>hHMr^A?tnKvEX5CbNpDcY@q+}ju;B)p0
z0klyWW8Am0j(J%S<?nQ9j0ZbT&6P*RH`ykK<2|TtetO&OS@DamHrYj%_@V9@gv=*a
z%@oZ!t@Au(?QBcRado)(X2I8~HmW|cjyVI%5v9tmij(yBmxQj8!8F#qexmH~HJs2p
zV3S8w2zNa<^mw_xsn%;1u;FP7>!#)0GAb=JL06xY>C#^}Sto(?0h7rdyILI+1>c)^
z9yD+-NvhaXT<5G3TKmqAZpu81heU)<G5fowijgS&WJiysPai7^aOIf9X|f_3g!yJ&
zg)tDEF6)P=)qJF7$_gA(trS@)Bf4elyOK>=h14Dk6_uTsLKQpGEqHNa3~N`_JvKFA
z52vrjL(NglmBjJGj}<Nv`eEh*Ih4T+H!;Yq6M#k2^I$m&cR)rjDI&y`a}fBEcW%H`
z+lv)64x;I3{&bC);L+W3m1&FED$`<%A?{REe;;h3=-^CnJPpYeTY}oJN@r8TfAwEY
zpKDiWw7u!!)!9wqqbKv7o__GfhhO`MqHrXf<2XZ+Y10t3C`X}!q$U}GYDFuryJv6i
z;D4r8p8C$#6sX5Qj-pdTGEG&n=!-omZEnAzrfDI<p9IGZ9yw{MA!8;?wSPUmc-5XQ
z+o^VG?_Zl9p1I-H_vfVhSaVce(5via=~aopUent`nhfl1M?)=fi)`F7*P_8UqnTj+
zCt#sh4d{01;~-JHkzjumZD&j#CA^e7w$rK;H&H>->#C+qWLs%)LbQ%MWAwDjok)Co
zVeZPmtnA#+ik;`f;|CA87Y6!!TN;BK?heIrEaIG6OX^RcRHbg~H<hOBa`b?NiT8Z5
ztkllD+Wv|tRRi{--Ou3Nl*44e6ctKh|Hd>M4s|rpN6(OyHJC=U-ItD&5~zY+cp}Ng
zI>5Zv9W_))N3p&EQZ&d{B?S^%T%l1pRbJmPYiI=}ydPz9H$P)YHaD!1tPPke?fV0!
z5^kG7$q?zc9?q3k;nyFi`)ZQXa5fy9+rcE0K=n8xiAw1+043rL!8~S~l-RWa%ra|J
z4oY;(BVev!E)i-MQ<pppZ)cLQmZZ-eb)TKEOYA60RZ)MXT=N(A?#Rn=;y7U?zR&Tf
zUkYfCHz*_l(*{nE=Ol9nOE7HRrcPlTi8au^6QOix&eHbsr~nEds6VyT+lNjwL!1R}
z-!h%47)fqukQZIq$!=DkgzUXI69*HQic1*9@Hwc^M>OMi(tyD*D$*O4cik)LtaDi9
zhIDKM78LaK7f?2`TVbVpo^4vPber6vh_Yj7Qj<Zxa0o5fM0lT_F;c1T@8XO&t)MBa
zVOWOwFojHi(A%cIUB9tIc+xL|sjJ}URDO(A`F!t=iO+y7bq}89Atvp*&sIQO{yjY?
zVQrcpOZBUgBjm$$&kwJRLqgd=9o;fQ*NZ2l)Jam6Mvcu6;K7tbkCj?iiccuetZeUt
zG!0{clo7=GRfnSw(obX->4#Kx8rEB-VdUKJs!9j(l%(k_liw)rd9zC%Qv{?92?_hm
zPgAU_ujJ+G!nm3R1;Ee5ZtSPMB^`dHJPF}P{o4VAE9f}A6(HbG<peWUF&j87%3edE
z(PwJ(g5cxAx6$is8NSgXe62csr7C=>GJLKge5O2nS{A+#td101hcYzD69|KJk4?5W
z^*u~)U-8T}91hI+g7}-1LWbe1miJ8<@SgrMhb0hfpuL8Ng240mg?q;E-dp!Uu+u27
zf*4Xg@*YyU5|TsYWpY>aeifkc89rjY*K(u*DZNQ4Uv}|y1|YH?SwO`B#-5ZNc<LiG
z1nWZZV0K=SN%0G#+ws-P9h|3GH`PbW`mA3~bkN>*QA8I&{pjq?a^r%-3`q8(fpn`g
zto()2RnnT6H(;_Ukt05JU-%cJ{+k=}(X*Tmq(|aB3~bR2;l;INFM|S&r+rwRmS_X&
z;wDaWl+#?|4v%};N4^z#m>o|=EC`B?++w^~Knapvz?Lg5{b{dsCz5MT!evDS_P>3A
zVnPm3y~}gT>i4>*$N+tE(|xKOKpw^gm>6@G+khEEbe3+Bf^;!u2Fz@ukr{uYBk$Sl
zly{&QP{A7khi6MCJ$JlJH;$}gy{Ih@Z4S^EhQ&%gR(W=j4gE(i8GJP|g4@JZrTNJG
zNEs8?B`DNFut|GD!CtWXtyXTbyBJvwBYy3yVNJQyGw#g_ZQyj4CG8xdd*X?z?LK0T
z{yDtwz^d#$64?_8pS+0}v}+tT_f5wrMrIl-&LN-M0$QY^ILoZ?FQ++!G{OEn<rI20
z&(1;+a~{b)<U=ry7eBU*ximkh0(*5cS988Oj&qqC+~E;VddIh7Pb(}V2^g*zQv!H5
z6yB@7QV6y+Nv1?D6su0zeRHe)<}}A<hDN5>CN`Z}7{P;ldg5I^`O;f{%?q!1o~+n~
z8pMER$sg1!w8MZEKs<Ys0UmDzCDKERx4=jJ*1zO1WwlZ=$9_W~epU_jRBbT%XgK$3
z%3=r%Zpi*kLNKifufMOjt}~-vA1euldt+HF<#z{hI{GP7jkR~aJv!Y;A?Q=%>EpJ%
z_o!v$+olle-?Qldp>i%y`iRw7@Psa}p^SRbnY(0|^p4zhRWrSG?E6ReOKYIVx|i6f
zU0<BfIhav5n|Y)764*TJ`<vH{^kM-Z`7|xz72^@ARuua=r7s*T`<Vb~K6b9OQj3(F
zK{KgO3GC~x#9V~h`(Rwo8oDrMLUmNh9KH89)kk$)w~rnSUOL?thj>4lk77oTv!q3O
zWv*n?i`Jq-C!Pet0*&rGfaws6teNJefnTguDX8=9UQEIMz!eEjUaxtn0dlwkU)_;b
zM*;0}<vfQ9`%<E>nY%)HQPdos=(6p>@nrb$3VT-V)RSrs#!G1;Bpj+0C5R!Nn|8!x
zUY@2t!<7)ahEs_ZOfPf|YZ2+Q3ej9B5E$v4c_36@n!8}20uBeh5N-eyZ30G#q}A5n
zWoZBDXU@(^hQKyqPvwX{`7%rLHV`9p^nkEhk>$OKfA`J`$g%62gSx!>V4IDyzxpPp
zILI+hbB(8c<ktWZbAsR%%Z#QCa?M};myXsFr{0-5isfUKL@B?Wk?ET-BAGvp-XoV)
zB&=008X;||9ecMQ)|zNaprR_x^+FW|!<);Vztj0rxahmhskuL5Xy=(L2dD%JKLcxk
zVl9k1e0-N`X&p~0qTRKxnHz1IH!aXlbed;LAQmBeSi*HLO$Da_WmYUopW;|VcAWIi
zNpsr~V-C9#H+bpBsuWn6&iQ?$`?@M^Dd_9Xs&cp5F~efE*xORZSw8K9Vh8zo)pl$N
zGyu&~ZOaCLy&Ra;Y^>BNniZj?ViK(Vr0&RB2SJrLxFzK0ueYhM$wk4L?NDVk&s*yS
z5xCH&aF~3v43~-d=WQEpfavR1FkNH24iZg97-4^9HP^vmmp?5U5pD;7^~ilA$oDUK
zM~JWnKGf|CB`z;^jQs1bvj-<Q%yBMompAF924$2oJ-c%~pNp=@m62st`G5JdJS}e;
zS*ncDH+IRWmQilLh!9t7&)*apZj!f*geU^R<eL(~>#I<wY=-bcj=FG?4C<??>y^nd
zPmlQemu(FnKsxbx;qi--Wh+@<f&AiR+HwXa#&6ln*s;=idYckP#M*&n%1}`W@{t$j
z)GJ-XOZlRc<CT`gT&|y6sYZT*elDfx`6YP)N~U08bg5s%fGti*LSg5no1*q}p!4b-
zgQvFj)mh*JoBeypy?o-&014p=!(RlB%rXo|ri&vwg(@-gw^Zes(xhpMPd1dRB`W!C
ztus43v)#nvVDUCi9XNA02R8u~bHzxqp5+gVP;7ykDkt@%)rm?e#wPz!V6-MQuZ*Rg
z2MZSyCxa<#^+t4Hcyjt-v1#Kf7TXoIg*7d;-K*2rt88Umx1XY|s}wJGgDdgEK(3<p
z>e%^67;i7lys0Y99RHNn(AN2(%EgoMWa(On*nfdm5{$bdObF8xBfW8A!8;d?tqhZO
z)O9?!iaO6NqxSD8q7HfE>`4-dv6a4Jbl}m^t^-YYzQVZOWk0coEOx~p47sfKB=*Ha
zOydHcq=l|KZgQ7-)zpp=pa@TY2?gnU>5Iv5=vyIrFitzy35`U}lBGUC?5#viRq%an
z0nHq?ZQL*nz<j}~*{TCE@*V^oP$LGnQ=oV@w?+HQC~PEWk!@3Z>=Lloxqd2fVTdO&
zs2a63;hqKGZeIdTyJ{Z_JY(2;n+DO&Z>5`fnwJz57}!tm&rJ5z5c;ONf)zZHAzxx3
zqwc%qtQASMQMbU8Vn^+o9t%XM5vq2vf)zMcni$oMqjt{4*LqEz!4eb`f%87CJjqGt
z1=Ay9wHf<qM;+^QMgb-->QOt~B4`(lkjX!4vjwe5IaPv-^pDzpQ?hBsI|me1@1&XS
z%)uVc5Hh|oRP>vS*p>s+FWzYT*4c(2t=2wj{XkqEj@l~h11xWDN}Vk+JLzn3L^>en
zsI7JdlsaoIaiFlE8z*;S=g~?zc@bVJt)NVKH!@CpaRx>EHWRTYD2`U@hg8?AYxaNq
zb3{9reCrFKaMc@uPZX9mn^y4yC8?~?YqH!E3OLT}IpW!_SRV%EOkKeap;BJ;8@$)Z
zXX$UG9Ei9i0q{L>80?l2fpNIg1&7iBf2bzy)QK$=y@Q&02ut4G;+X*BNH%1$XEa$E
z*1EBlYEdGU!l+*rB5|%B_XqP;0){*?s@`ORc&0{CQM`-AK2dB6nzrv^a|Uc;gnUK|
zHWSEpzz3(Pi98V0C?;osl{XIvp`Rp|Fqo@?szgzMUik1Alq2v_oRptfG310yMOFjh
z+Ht%y$9PN^r*XCp4dZ#7z<OC~x?1!4xe;+`76-_^)GNL2QwhmOBs5S0Kj0*gk<1<E
z>)(GYGupUjXs4{N_327gD4FYIY<pv?hsRb%2dhW7cl^rxee%wZUwh?^M`9<C0K-vX
zw3H+XtxBjA5|LJuR1}(-*cqF7YH|OqVHWCLQl<;dGQZL!<t^RN?{RfXYVtJ4hasrp
zZWY*J?$$*PF{blx*!KPCHk!%Zw-%<*W+j9cB|O>P8x-CW!CwJJGC{#)8)@*=tihZW
zDhLuO`u;1^cxzCS_Xk@F`@wBduVWRqXnM_GvS<Q8vX+2jO%5h!wtm2Gb&l8ekP7Uk
z2l7bxxucR>;%01+5f;!B4#eH%qxrn$0JBcfiVakLqj;qTs4Ohx`4Y7^G~k^VAw&Y_
z6}jD6TtFQ3M*U0R;4`<83070j3*g<aAB-PV0;lpLHh1^H$|B?YPDcB>r0=t_1e;gp
z(Di4p?twYuYwMy?Uvcg)UQSaR)ZSwOIT3|^taE*r!g527Yu$8LV~^6VPnMiXhsZSg
z^UXMh;IfN~y2njVdyV*@js?mVOJ0F@@+C1UfjEVshStgm^M_@)16@V!EgDQq7A5t;
zIIPw!35>yWrz!7?Vz!X*%AX}B+=vnjJ)iR!6OZfA%E^I)<cV&*ZSe5j)5bT|9JPrK
zrrq*QATp~LPe|aJ2<Y;rC*Fl-!{;z@5M?#&av;?bF1y#&!xwHrWP~VtIp%OzIBa+K
z0nFu9Uuu6lyoEWauyW?(mx`rm84?2$T=E&3Iy$GOsW5c*8&_K5>FBu?Op)^aQ*OU?
z?;D%ojsU7Hc2cjIp_f*+DgJ5<a*>3O>Sk&U8I~eFLa<noEkY~zXW(ukoOig6CgluZ
zR#)7-9_ky+YpqM;p>?a);DGV~^W<>Gj4u&EuP!Q~Wr!Vx@$b}G26qow!Gl<qR!?`5
zSj>mdk)iwO>lV&IfXcnAHj7jctSiLAoT5~F26h~3LZXFQym^K}Wg#+cN@VHKgRI~6
zk3tsCir>Nxz<BNBF9PzL<8Yqf3J-W)9NiK<&Pnvi3`j0uNL5moVy(rlskK<Lkm(R@
z+*5Th`K6WvlUolBrsi(O^O2Kxa^&L8P(PmhuZzfH8^A$XgOMuiE5%SoLc(>w#3LpO
zMg|<+*8V|ej0&-m+lWD?f^f$6VZ|U3BHC68BFVzeoDTuMQOT}8NIOCw-87vaJSKPf
zcOISF)?eMOzKz?}4S9NJo};Cs|DqEg^(?-xMDi#QHPwy7PcIBAmD`fRzezw|D;^&q
zNs7jzW$8v!n0+9>Cu(xDBr1&>qZ*@0#N7zomk6W%gh|^q5!Z(Gvez_05B7@b-HoRx
zk!I%gxLSBo(d!x~WpW|A_XC*jtNhymT$MjOSdQ}Hgh{wgro^J3?tm7>h*jys#x!V%
z^QMhPOO6eMOS_Euf#;^+t15{MPWnzYo$HOSX*Y@&X-ZfMHF6i+N<@P>z!DD3m%Bna
zwQJ#~so{<bmQ0Os7L}ymdEG7KQV3hQZA?&I7aGo2iwFXI;}ScOdspxy+*$y@cc@_{
z(gWkeX<jP&L>ODycyvtqw#yEMCG=CZAHa0hc~K(S7O+pidNnXmb&eJ0b~yGpnLHW=
z-iTM1#0Z@B#fCbQ__CR&hLbgRiNi_4vF92Cf*Wr8(CSTs(-v2)0y<8NIm7k9`+|uS
zKi!6y7XO~KY;%kQoa7=mc*wIp@?)Sw6_FUHDvR?|PUp7oxsPEW*4}HD@IytcYbM7(
zqBRL`<_9QD)~2OtqgBQRB8T+p>XqbN&IC?b(8Q5N$*3G|1-#+fG~y$g$pPSawqJ5d
z8L{6VPti<o%GETTQE+gUdu^s?Ry~*}(FY4h*5!hu%TMfxeBX~L3?Aq`N9CM3W>0q+
zO&(I3&8*4+H5B56cQSEZJU&s<)99lBluJsF<Q5m@MwQe?2A*=K78|AtVPR5f%af~z
zCRQeQbqjtjJ7~uK)%`V-3&u1IAY;I?re;XQiI;n*x&2Ko^-m!0$;!~t*khN5h<Zqp
z%eb`AfHL(7RqfT6o3AfztI#mBX^k2@Vd{aYRy1y59b&ShHl<|z&gR(JGk13GZoavg
z^bThKUEtNw?8@E(Grpc_(F!e8YmXHyqC!K!h@a<_+>y{Q@{NY0>N4Mvv*zpLU3`($
z4u&P!8$9DgKvb(BFQcAoLSAjlcu<(Nfh+@YMaOUzM7Q+>cyYHt%RZdgDYoSjjz~`y
zT%N9vfO``?2Jv3Sa}U+3su+R8uq(3GQISyotaM87S8hiSLI(nGN9KOX`rM9!Othkn
zON5K5x<W?b*uvJv1_H#iw%!yFP0|rB^kmfw(^5gf+ZyfLmaf1Y^9c;p2QeUyn%MP|
zJ-eHc+H<FGIccWI-QNC&1<)YIn`!AA=U3m4kV>xx*{9q_)|gS1tJ33IwZKv0Nkm7f
zUbU`gZ6d^<5z`0;5{F!~*%b>m?B>*(b2uy2dqiIb(ee@hO4tK21v`xkUV^CAMdILI
z5al5y{%yeCt$&6(y$|GpuJ{aWmJ9=2C%Jr?a+<lx7o^LhB#=XPhZF353oxkguLo6h
zjz2j#?mI6d5q0*lnnd@oH}6lNEMG2VlVb=4Z&1|A`EG@wyq|ZDgwfFlpNlEpJg*$$
zpbrU~^B$uoWC^k_Q@FU(C#WPWjHM$qF=X(EgKod>{agDS&{26^%TWcj{)K-FbFSPW
zseT{|s}bnwt}$E_Hq2mL$=&lMNxOeLa6w3*ncV&h%gl1-E(kaX-9@b<X<xWyr9jnQ
zuVt(!u5Xk+Gd=d3(Z`UeGFmr17F(gs2M|c})mp9!6dy{#qRXEbqcKa;hqU(0H1aul
zqwK6_$1o~1xuj;jLE^Zs*Q$iiP)PTE{VH@E`@Zgz0L!0>D#lahbyn(X%OS6k0H}-U
z;j4PTb5uoB(RgDDD_?}`>!p7FkeByt3~W-uqvyHKLe#X2=W!VMeNXWx1MM6qoGh7N
z`N}AJb~$tAs0#O>gADpy1E=&skrPYlr+VudC}C;Kblt?{{^XvRK_M%&lu1%QNS1og
z>*r|H>mMV|(Dib?Dzv9I7C4i$*(wID+y1CU&3s!~?Hn%2oTAcjw;Aex!y!5Rkzjq3
zv5FqqA32(fQTN^AaWx0ltU|Ly|DHL|lGr7|v|tv3p&+7!tu8wFHQJ%W31vpZo$3=R
zhf#Dnz-@@_VkY=((LiSjGSdc-t1=FLJ)^2=eF7y*pvuDbGPIRh0<3t=SDyzKYucVb
zS&YBTqP{xuCO0L9ieS79uen+<IHfT(1<`JPay<`t6yhQic_J4z*PNj=K*B}O*{|XT
zC@R!%j4Z8c{KO);U8|wPC4*!fZ3r%-9ZQbVMZ>;V8HCN-M?!LO*<u_l_REUZD{3Kk
zWl$|znc{>;?d$;J`EI{y@K=M~N6qP0{2qJ(8(;*7KQP6<NC~>!6?KJJOU&8LrcJMj
ziWJwKo2|TVz|)6b#vR{)b2Zjnso4jTA5+yQi}G?;)SH5sg0|~_W&+j6Cl&ksDach(
z{A(dPSQ<Goneukq*Ctw~3DuGDl@(MUoCZZ+bm&~x1oHm<ZGa7SVjoU&n%lhS6JG~3
z3`ZcKRJDzOhCOuC^MGl3W~(i7_$}y=GJ6x(>x4PxGiXiDf1Q=2C_&rX50n$$bif7c
zpcyApPIDt|p8%;SG3yJYfUrUFva!AYo9>I1P(#L}IYlquV4$)#%bDI3nGzQ2hNb3C
z=Cy0Y@=l%QKF|7EB4~+u)?p;n07epB6i3csYw;0x##-&FJ<zql73QL)P`Z-_6H1e=
zvA?=nTz7I|#mp^TbpF(p)3<i@jVQ8+f7Kp}?+h%d(G+UQ(y1ko7ggr>T2nBY847WE
z$5t2J>l1y$eV(%K{Un-}HE4WvsJ&Oj)M|w7IqFiI$I@#zpu)2l7-&7M7JT4}z&lVq
zL=wzm-i5qCS-MaImT5Z|PW`+|$}!xpl$m`-3ue_M*Xr4D<1CgW=IV<w=D0C`zLoNx
z2zTY@J(`&o(O=QMWtNmWuR*U}3W;aSYU!u)2y~UG>D=ww>GyH6j2r0b$kofv1j*Wg
zTMd!Ba<g5HsGO}+elhr}2hmj%NRUJ)7dZ3p%Mm&WqF{-m<)A?Xd!TPIIE`@Gswq*3
zPUrpwBhVh_jC$=T5x(U*6tOV`oyK=uNPNb~3VgV#pKfyef-vaQ$EplsXwz?zZwR98
zuj4w2M6K<w!7{p_EiY5+nY<ekovhpy7pE2G?((~pJ?S)|dx3mmp`R2x{^yKS30;2y
zm>4@n_^qAwnh%15#(o;T$j}3kRLlfKe0=;IR?lBy%ma?N=ulww3yGA_>iJP#$?r|R
zYDHaE>o?z5xQu-Fpu<&u2q}87`((%QSgk~bUw&tVO3z)fW*Bw(GT=7*#HFS?(qGYY
zTey<ae!_Ku8&q@$>J@NV+DAp<GwsClU86bhE=f-26CI!gaYc{Y7@Zgb;FvC&h!x3=
z#{^yQ*$svtLaDBLvlYKI$a}bo=3b4CDOujEz@Te5%Gp9w`!{YkH?Pd6)=%@{87;`z
ze;`y05!qh1VU64%SOb({`@xxy8W)nJv#9bp*f#S~Q*Zq<Z{s8wt?a+_f3%>+R*E(F
z-i`V{x@RWz%o1xSk?m(=q2)w5+{ygl^2qFNj@`!fP9Huoc-qYEn@U7hbPyDOa}Nqv
z1V~wFBvcDX+!jB{DyUSl^0K9$J$r2D=qvv(g$YPbHzX>1Wt}ZHRJE2g7lto4CYfgR
z%p+!F!ZwXtvdNw-Ubi=EcWaxQV*PENJb&!W<?Ek4f93{X1sj3YX#4$5m4l<pD?$vj
z&M8aaNNWFYhT(?5gI#o}xZw#mxhCZnle%hONp+*LzR+L#Nf(_>n%gXzL(>^<f~kx!
z#h^*H>|uNDsy(*UHd|X`@7#j>xMN3Mb;h0eHNWeXKX~Ied=4*MhY(m8hnFbgKUQ&$
zI$p$_D!tNX!fBaklF6l`6msNWe$OHQ$t0_sa+4`{S!J|57F!-lE>S{u>6S@36)aZP
zvMf@(JP8OD8FhlaN@0RXAZ}0+`e_8}m#C(C0$OhE5A&{W(GFVDB@G6HPZt`K2yWOG
zY+VWP){8W6V@>3}+`v-th-cpAq)CbDT?u;Q2)1@W(S0%aC1E#GIn&3uG`XOf(sx|9
zNi>p;Zs`+G6?0;<rnyv;gC$z`_|!c;Ti$Sb;enO$RTwO+8}xK-tZ>hawMLq>d8Xbd
z7UcH$c>ZkBqZSkUlyx{eSf<SH#r4&*YKgG$Dgw%KOq|<H!sA4@bpBg;C`trFrJEcb
zp+8d-8zQ}v8tsTyT@qzFrJ6%#1l-c7p~*LNM%FqDwOpg<nLb7P__Xx?Gl6utxws4s
zaRmo*6FO5!ISaeCiQ>AYZDhjCn0^kX)%~T|$)H*{brt`FsXicNX>{Fdy#zAd2}BPC
zIJj>2n8mn3+Z^(!VNF+%({Lr3%J6k6V%HgjbMYG*i8xXqc7ZcH@5BD68QPn@k~2$_
zJkkxp*vcGh5Qqg|0rpiFQ?<?a0Y#(aYu9<3x;$WrIAmR>yw;3voeii%T^iC$=qGTe
zK9_r?l|vA5Zu{!+(%>_YulReOEO%^+L%e)bQMHi*o%6D8%9rI%XHyA@kH(AmzYff0
z4>u!~GHfJt=})c9&Fh^S#)uoRXqn^`^1XJ`Rwb~g!)!XU!&24@jcnfOg78~lq1BSr
z(DLoi0%y}ARDtBAHjmBG@jT#T-AmV_9&<oCfU;;0`#M&xm-C!kW%+4zU35(JPsYi(
zDK=pwj^nO#cH?s+w`Aiw^jF}bYz3NYuAK;|#j44j5+S=soYl<Zu5Fhu*H-r{r|XlE
zpn<PHx0QMd@p<%G*5E)fl{N2X6u+RXiJ^y!LD`PG##5nm9?^KsT9A1kxu3i9<feGt
z0?~h-Fp0juNs4gPDoHyPDLB4_E~I_or#RR$aU(ZhHQTJ3-ztsTGU)Y}<#RrNysBwm
z!D}n35~ucKE(Sopr7};hArptgQEYxO#Zm2vv=f8-UCk2uwD64igr<zP=b`o(q!&6Z
z01~sO!$7<v9nMJt2LR5Hdr$^bY<&mNjZN57nZac;a4+f<WOg?^WXl#nG;Io7fh{Bp
zO6w4-&q!<-VnodnhbG9goF&LUcH~Z8ilKo@l4ARQ&jaz9I3b@8@;2da2{f@S>8&tb
zbRT!UtaI@beD6Cc;*c-R-_QZ)jjNVz923G2*_$@TX8n=uZ<LcbOjf{-bYg|xjVBLQ
zvnI4GE-jvHu_?O{C-B_(5L91`!&GNpgCHolbXqu-<1;V~OQZeZsp1JUp3KfhOhotE
zwP*}Hi+ALPC4tk_@&@0i_ol={4XIHDVlHf`QpP7aI2gl#Q9^gXQ{;JH^o`n}eO8zU
zTj0u|1zeQBdS9qAz01~Z{jvhM>Zo~ZpzF@;x0n0u?(IN#d_p`^4N(m<VV?s&o`xtd
zOL%o1=U+8%iz32=fP*s#6&$J8Ku$?;zO7y^>vzA`re0`h2oVWdS)_KJKAY!(L;6p$
zo-Or*eF7|is?AM8Px^^|Zey}n&(Hh<<f1yG&b8bbpPuiX3nQ?I0zm1XI9(*%F$Z6}
zk9+<{7FwfOvo53+WU?m(@{(3c8Q1&kQYzDW`?I{GjN4VuT_o+4qBJFF$#Ao5ox=OM
zJU$mJc3w0sC>0Tk^LmfJP*DAKNPSgahTj+*WauY+@CAz|=m%decuk6QPq+?loKCD`
zMo9HyBy}KBlr!2DF^AdgcBVFkG7DcAnW9#Kk@LfOUorVJ8a*q|Fu_W2Oz`^TTJdnV
z+dIVrx_Y3x%+rHIuAUrgNl^^*Bh457=0L>C=L^i8ZDXQ)p);BR@kxik3Ii&{m6CZ*
zdiznA3_jtWHya<d=MI!tpL9)Pc2F)!nt9g8_!^0p?XgKcK_nKG+IVeaZ8@@`MnSAe
z3VKH!DG=1mLaOuFVVH%%%x*=W06{>$zm`;Y$()&!gcsw;&1-&6-eu0+8m_i$Ce})q
zg@}|;e%2szMy3)n{E)jm`(Q0g2o7C&Kqa-<VZPKcP1O!jnqzp?{*)k9qpW*SCEq(L
z2X`#Rl<VxW6p0W2)CR@v@om6{YyCG#ST%UrgEow<Vm)z=W8z!HpU%CpB>rY!32xk4
z%(ldf(QFtIb2rJN8kHk%p##Ltiyn9^Ss;2Mve2V7y)RtjiR3ru6>o_2zwkmV$u$sN
zP?7Uwp0_f!a7w=wsqb<`=JZ!Yh|7$liZ6<Q;?T6_i5?fec~rESc=VL312*L5XimS;
zKCu7}*bAN_7Ds<Y4`v}zNur)R%t$#kNkVie*JCU|OU0>JCzHxV@0YB%tNm3~+qqnJ
zq%@{OKKV-o{M>8b6h-P7eEpQIm>ukoQu+nwa;Fb4vo2d)=A=%_HQ;)OXZEE>F7~wd
zeD2!-31bZc2gv9UOfX_vZ|f+0Vr}q?l^B2jUqPWYG{xL<oov5@k=AvyrLepiwei&h
zGdr7{AKr|Q%kJ-y%U2z~@tM(Mt~h{KCOCnLffnUXLLF%km(?sGuLps7B}|OIw)Wbj
zuBSHIXX`!87$b-V-}^3D^)0{M21~09@NupkrKvXknBLgd=$jtZv93jA#U<>q3DD?m
z4it0N#nd#yT$nye_cl{!s86r*(rbTHeKg0=wO2?F4RCX7!voG_8rR@dOgGN>sdJ$^
zoCk6^ob=)BQCadzeUwUE6yA#6?2CrjTvC7!kdM0@P@<h|ARlwi%6)ph;~hL~mM#u$
zGX`Wk^#Fw&QWZ0*WR^>u=EcoP)I;>ww;F_n5)ZT<erMn@d_EG{p@*ylJ<FxJe^NX_
z1(zKwq-@=uX*cn_kP|e`x=&iUAO(5=^(W<dvY>hlcBl{I>rz=(c#tRfmCR!Lg1nrT
znM<eesknYLoBVw-A2Y&n7B3e9u+!Y`J><wmc7T=9^Ukgz=$S5ULFuTcqA$fo?O&Y2
z;5Ykw(N0Yv*RUX;q7`Kqs}<PZyx9ygAOQ1DTF8>E%ENaIVCt4^g>XA*MgV<82h_NI
ztw5jQq6_0e^C*MOcwq4A<&PyC)B{G<)U?;^Fd=DrSO=3f4~!wedCZGWPjLF%hkeax
z)@9iCouN|uq2s@W67ofK<=gl!)j~8!<Upa9?~vmT(T`Ond~s9YLMckOz$b<mE0dgU
z?@MfV`n=FR@>I3zb)P`Fv{o$K^7DNk(KWUtinM#s$=4>=lRl^gaA79rQo?TOFi30L
z+~b}f1O*7W%@|XhsgC$qf`nUb)jIrc&iNgy5tzf>U5#|Wqun7GXOX>pWy(i~FBg~w
zfa5$&!H$X2v_sp~pw%q9Yw9$beyESU)IB(WGaTb2m$}7b-t@V@f+7rttqoPF^YVK~
zwC2Z!<S3e2%GZN*Eo%o<*i&1{SBZk{VF%Rb96-U?7lHerZ6o1M^TVv}$f(gA5iM?#
zNK|RSK(yTz*i6v|-5BkBVM_TP=-|{3he+23aPOR;N)|*6;hor*`#8@fZt<#5#1@4u
z5DzDT&;Z5gB;UB%u@tFnB0O2k-~TA5q$b~0x)_YByRQ}IcQ?H>%QuF5ymrmGZ%0|d
z1{V=#%40M%?eS~HLYT4g_^JnXm`VCe2V>iHFunu}0#^^lE+!=^{=`M}jd2UdW#qT{
z30TgBl-qs{R_6e&nLz~nv+$)R$Akg)uARAaM(x9qH!_>U^dGf6eJ+g_MG7zneQGm<
zha1Z>P0IrLRu+1}DA57%-AkqjDS(JH5QE7r#6{%JXCo7z1Dx#QC9g(%O)2ji=lu8u
z(pfQO3=LAYVX?hIiQ`cqmFNp3sk}|$(S?q^SjZ@4ajJ>W$ey@w1}bRWX81E0YQ~L5
z0s@Wj9@N{k5KvbY7y*AnR^0rpvLv~HaW5CVs)q9sd3gIWsv^GC?cmTzgZ`GB#~CAh
zdHgYS24Jgce|XtP3<Fu+p2p?}`y1PZV3=tMk0wCXS|8z|D;r0sHw}6oW!-SJOn%m6
zoh&qoKGFcI9rK!73G@WRtCyKf&*EInARqEecLCP)4AIdu%Q_CkK-YKvP#)tF4|!37
ze#$xu2**&s2!I#JTQ9XfsEjrP@O<|cbQ!<XUs{eduH7IiZ)2V5{hi!2JheQvcuPl5
zoI5Zq+&B7l!y6wQpwC1*;)feXCR86di7>|=iDcO;7J>~FT}~`yFdgZ5C`LRpTNUWR
z+8GyQzQR*l1+(39A3ER;S2Gzuc@K^Xb$M$E6wwPnPZ#Czpvph6rQwT(|6{uVf`od#
zM_a>u96J|u*lcH-O<PR1fu3Ex`c7>VAa<m|{Os$~D&_K5ttfgRI^4T0RA|xBsA({b
z8vj6+dS7(v0#K~r<U_de*w1Ygwa*#T^D`hT!c}5T8~h&8U{mUE)*DqZ5>IkqQsCM4
z=!HP_SUbw;q32hyo)BMyhFAW$$53catjp&s@N*wNn$Dz@|NlJfJai1oeJJXA2&OkL
zHO22AePc;X1}ScC77d=UmF7X&6X>&+LO%I}H!ijCbi*52VXZRR-Gd`Zq?W{K<@HSi
z_htz-aA$JpY%TF3N4t-SSZbkzzPsRe3D$dbDRQ5z+SAs$heVce00dQg#Rwnr`_|?o
z8RqM!;k<XKx2X}Py#$a?Qac9C0XiVOHL(*VT`wFpLU(MDk7I8hud+~oh8wZ6n0fP<
zm7m6%!X8;p)*?A!1RNg%$BUEuD*G+x8t2$PPK}z<d324Zglr-*%Z6CcefjIYCX;E*
z?vJn5HJ?kJ*dmfeb~pi=g=JD^fdgaYwcl;#DV<Rsd;LR)ZZjk=d)pnr`+r7=^uCI}
zGWAyzv17c5tv2!@-W;=*|8bto`h_sErp|tv&1wDE3(i%Vm5g?=rvsgBoCyxe)P7V2
zl2D*>1Pc|ZN>j~s(6LT+t<ZCHqKc_l#5%6S@sgtqDU$j5%}d|GDvZK<k9tCHI_S3U
z(X;yV%yTaITt_p^X%3jOV$YeccAff68)Z7CXUxfCGh4)BR<^Aj>|_rYnX+QtTOT{z
zIB`_FT;W<))m2~G<y}3sLJM$?MxIc@i6W6?(#Zk>lspP4rjlyvXrP%6y69z?Nha(#
z;gVa#BMtD%JAV{IlKtpU$Dg`C4SO2-Gzm?Nu)qm7d<Z0rNa9HYN-<?r(#a%y9CAM?
zJ@bB+I?>bst<@d9(}{Ze@+dm)0-420VO3<fT8*;gDpaRQn`y_+Ja{wpf63D=SQ$?C
zC5jO*MZZA{UKC1ghSf*;MBOS@aRrfAG;hsTff=kH8-foi8!T^S+iv!Duyc*~t5hXZ
z)APPrUK#6fQK~DK)(bs+0sRMwp=j^e#8VElo@rAg|M_`6fDPlf!C2=Vi|*DVdO`o+
zocCl+=K6*fb`_huo>~`eERFp-SCeNdYFf>l_0@dbX680g6Zkm1kh;~izP8V<IscQU
zC)ur1@y-cE0a0FAOSG-)aRY8_-HtnTSF2u#>8hWa_7(C%Jf4O>HKT$S##rKv2fjBV
zf=FF>9;H-J!vtF#a6HL9^LiHXEM0|e=VDoJ^j@d>t#6N^=Osv#1gUZr8)34Ax6Sh_
zPc4(`SD$Ys!{0nDGinl3xNam%xmb6f=UC#KfZN-braa4J^{?<=;Y9aBEagl;B>v0T
zTlG}kRVM*4YG}E6eYqYlZk#D6Tc->ttxMAhe9F}*S7Lmr@q$vZl%0?%nabM6?L~Ld
zIramf*s};I{Kr%a{Gzw$F0!I)^h$w|_h!h)^HD~Q9SLk4ry7~mxUtb%loc&SOEprA
zRz8(?QQzRNmTgcp@<t>7JY0O#K>6$!-$i9X{J&EBmtIWjo0L($a|`>q^q#Ymql3Mj
zt&O$Cq}3?pG9!i!8PumYx^!sMszp=Os8XpysbYl+<bleG3~5rOh&!5MBRm4bJ6yAG
zu#0TI*8(VFJ^KIWSOdCGO7TyT1kjV1Zc3Ljz#}nB$_71FtJwWKU3dqH6?t`?dJE|4
zQojaWuAnO&0A1(RiRuK<*`Nwhod7`RO^{cO<`zR-wA^NPdpW0i1*BgR-u_qy`1dOE
z#2fSS7;oBr-|-+>e{*m%!B-9WdHZ~b+M+UL$T!a*rf&t}cH~~iEBcQqjvc7xAQ4D-
zOQL3~l@vg7+({$3puAUnzrk;!f2q5x`1ZzC>1e(w?$`P-MC!&lt`huP$c!X>&DM{7
zqW?u<z`CE26!$9;f6&AKg&<{2|0_D=p1gz7rxa>Xy&Bc5Ry8SaJR~S+veb!f8{Nj{
zTR7LfAS15ytuH+F(x>FAc^#*+Zz1~Rc{2SBj8?@9Z@l%dcRu>;ON7bH>a9U<Y-t(&
z_cdG}a;1^Si<!8vSiy1QButbbYU~)H#g~vGq_|>=ExqItODn02Qk&U~vdSzc$y7-t
zlTr$4rJhQfsiu*3YAI)&VFrhLjDwF^W%@^WtYaVNxW_ww#!NE_qi>!w6ChB~z>8g6
z_KRNvG66m?`n=TZgJlqlB9%-S@rUN!qHOZd!?^(t2KSldn{!sVW|w2u`Q=_fZh><t
zyuc!hE~uzN3oE3!VhS#z*iy?ZznoIaDy`&l%PymY@=7eeq>6)9RB45k@RPeA%f0n5
zT6oCQ3mX@ofRLD6oJ47IC{m$Kk1<O&Y}s?<&V#QIVIpM629X0QPoW~k%2lY+q(!SX
zz4|R%vti$nGq+OU;b`&VBS4TMCCXH&(x6F;HXXY3fMm*&EeBMCMopTvXuY4fb{)EO
zn=}<BdCHu53l=R|v1-k_O<T6@+OzM#p(7_wojG?&mK=Es)Tp0@X)|^Jkt$P~MWs&N
zDU*Uxg&h+1sb<IxhZ5cznc;NPI*=M*E}S^S$0QRjo|1|@Ws#ypixFqRu^Tc@tcb_s
zJ5%^wFr*!vzhJurl$+4)(X?6zCLQY0U=+{~6NL%evLuLQhgqr(k|dikYtFTMdq#v)
zHIKvz3fM^$>SXGQCr!;>d~+!mwpYI#V$XnVtvHF16iJc<@s0Qr|I{Qxd?q_|17J`I
z03e#dJirD(2H+@7T55LUB3eKe@W3UEgDgst5@b=69*{*FSr?s=Z7?a1fdvZ(8#XyS
zcpumJz$aVcbeI8YPy@`O4LX1oOu+`Q_K}+#+jt4vCrZ}=eLjx)hMy3x)sRagM%|k<
z<<ZRZ_QLc3oRB{omPdjrTF6JBz>5qyz9>@U*OqYFg)(LCDpzj23Kg1E#-zaSnW7}C
zXPWY?X3Xf`Ia1Jo+`?#%S){z9mMqz3Io3qzHS3h*huNe&t!>*z*^5IFT%5V!x{sXo
z=K2384+Oy@e^R?RCPSvwm@#jPB}?k|kke({xN**{TR|Q?(0lY~`#$kf=(~XUAYG^j
z3L-O+5V36XDXaU6o!RNai}%m_pCT@ZSZ@5(9EAriQq22EvL=d;M9yO<^^`F$IrnLU
zlpOd>o{X<CdLE_YwD!;#-vA&(3a|E)Jg;pmN|Lpil|s_*7NuxRo0#&Nz7#&6W~%sB
zi*`Th(BTiAy8I=J9y6=y)u(v|Det#wP~O*ax&IYiT16_Ae~lRNkMSP&5)&qTXWE#}
zEUswI-q%@s4^Cqv_7KKK&!JS&?=XiMakwK4IMR{&9OWpJ9PMbsj&ZEgagI|s-toGe
z-~>ZXbfR9TI@PE%oF(&ce8?hRuz!(k%&gpeHja*{%;NnYxtGLCyH2|F57v(jE!b{j
zo5^--l1*t=-ZgO+v+|8+6S&#UCYw7b-G&~CM_I%_z2z;F&%2c5?|q+%<M%^S{MVw=
zNQ})YQ>OH%MP;sJQ<zoeNp`$NWucc%{jPkpdJnG+00tq75ROd|A$BO$XH1uKAcUTj
zq-EK*ZNhORt}FID==*k+G7u#IAO!;DAdn0UrjRI_LNTP#SUR22>v@C0zR{>OnH-qS
zDvO1)wsvS^qqenGI5_AHbey}O>&g{l*RC15al>HmIrKlz%RPoE@d@HFYG8oCa2GQj
zWdtl(^kFxljt~(dAjF87B54wsV8zN7UkkUPAVLHNQKHPrkl{eRwXNvrwl|phMh_5}
zioRa)Qeq8=CxEB~@dOCL79^PVVUu;f^679qC<=uyTsSpRqNq!dNJFw@TGFM{mL-c0
z2nbzJP<ry@(N~}lNU>su%2hH_t(xi9k|<9QPwEagLxTq9nl-b~rh}y}U2OE|Woy7N
zdt)&H1QD>4BpeLl$@JmQn6t{ox-C9-><e)0Sco&{LS4BM?#7J>_wGe{@+`{k@#@uV
zAHJBgUm2U%xBf1fH@{LjjsE&;{{AQ2N(<Tn0gki~M-Cln2~J-&uAL#mq#d{jbOJ64
zY2aee1Y8`NaS3R}C6_h%$Wh+Z&R0orJFW`%<7!X|TphOH8qf$_^KpN*h!N=wZVWf$
zCh86TxM>xGnK4t#oH-c_7IZAbNu(?5%-HPXLV4eD<*Jq&H={qaPn+)bCGigKmv|8O
zPb|j+65H^=lx*;@WMlD&v6(iKvAz>e6_rw@s+J~A5h$nvdGd_#%?JS40f8JrAl6_o
zKL~_73?={$=Y~WAqflJ1Sm8LFKs;U~fgqYl6htD4B2$D?sX}Npadf&E2178DDT2ik
zt5ix=sbp%k@^v~ndc72bL6*@d&1{xzvB<Ttk!@=$!_H2Ey}djK2Z@f3;+>o%IXf$M
zaRGI8RpjQT)ZJa-K6o`ss^tBQ^r1XL7)+S>Va6<%Xs7{!U(lfWe7%=Ke14kfAC3r7
zzljm|Zza+ZFpwk-o(vhNWXU2VM-DN0@<=IALQa`7YARGPP^F5C8a2GssS~0>gDg#&
z6lu|-vf3biUg{L|=+b3Oj~+|<Kx`N=V9$^tM@EdfGhxD)DN`ZLm<eOfTm%aiGFY;a
z&6ce^b{rIP<fI%JSQTf^nz(S&!kxQb9z68(<Y}1~FKfJc+u*~;K3~3$`0;bbpTAoH
z0z9Zy%hhu1072r~bAZC3M>PAy5wv)Y7a&MpuiglF_nWXkJ|D%`E5Q2|0u6`|fgqz|
zfEqmyO!)ZWCnbh7S()U>%b`eB9yR((fS71lQ;zrvv$l}5v1}`JvF4(eD>swto{qwV
zNBerS{MsKYf&^O=BFv_6F?PjDa3WEnODWRH%8*HI*JpW3Ea21X(=4pf;)J!<y1v^;
z?BLT+NqhP9TjCKuofxieE>PY$mt3;QWtS~;!wuWqb=MWoJhRwy&vkm|9S5I%w%!+C
z-15~|kNxLA8+`N4!nKj;2|mMdAP|U|_!mNg=!n^mQhv1-jPYh!BHQL2$G7YH^E@pz
zg9#HSY}i)ez_AVwo(lvBm?K5XTBuMUVZzji6a`s~7y$9&sY#RwEJ+d<$&xuqk;2(G
zBLs#Ifue)KaKqsw5eU*qBzY8yG8!imj~7QESRfJ|lSppJWHJ<r6DrjTjV7K>$HQQ_
zWHL>$Soqm&!yJyGbs6pBQ63zhuS*~hEE36=O6|&I1mtqM3WbSZ#^|Xi?@_Hb{iRT=
z)jHUY(K0>d9U2UJj7AM+vr&r$(ArwMjSVJSTWogrw!Rdytp7FFG`Q}%IsWvgMF03l
zsT*$acFQdxZo8||JrA7p&_fSA_SlnOh9mYV!?o{AhTk*unkwqN@kWZb-a6x7|I&Ep
zot@r$FWv_q^!Cw5hW$!n7hm9*1_WXk6ly38<~|&53<4noiS#oWndj`;>*2t`I~p4I
z_=x9uy&%}I;h!k#Bjmp%85#`6R#q6kT2D>@FJ5roykSgCC_a3U+lS*9`1192{TUtA
z@h5<ie49Y3_)m}^whgA#Mxw!&kd1_ZFX0>UGx!p5JE72T!?C6JFo48@VEg}%#bMj<
zG+(Rvhw+5rWza+iM~K(<U%+&RPYvO1U839=7avQIwL43<m_qYS$dQ^Vq48q@SsQA>
za)X`;Te6hBa=cj@d<Bn9&diE0fe)%>343vHsNzwWCX5{TW(s8zbFQ_GozC+zXfG(?
z1tF~MJ4|-gXPP^y1o0@QX`LB_rVzg2d=^*q3)5nmH_n7!w>`$$8V+Cn;$M|JR<eF8
z+}4$q^YUgfcPAt)m<dzEkV5MvWA}ODgqVc$#*n8IR|2!!mIHpcjp-^^+nlR<ObcZK
zKM&&M*5~~x@IB^X@YH8fVKefUbaQkvei|xUgkfxS-)LxjG?xD7NEUG8Y~Tmf;$LTy
zT#$BjWBY-`l7KOE?-O(+k*U0XK3J+r|2T`w<Ipe`xt+f(={6F8MrZDzMlXUcXaP+)
zjDw5#Tu{F(;~WE?pl>E{_vu%?n<FRVi2e2sS%n?{RKi<A%*|qdn7W<m$Cc0;MTMKY
z4W(x%dw>>c2@r8I!bE4iEch}mKEe~l!w+58WJMgXI8e(-xkVS~PMawUO2vEm*GyXS
zr$eY>Eh-*oKkw9s?q(V{(OJH8kdvim=%om+MKwj~4|iF~z3n(10z2)EloCh!wgBRZ
zuQxZDMtEEoKmD_|Y5|?Eb3t!lFRE&G6?B5Bck*49wVvs>IN^S97(-iZ)I`LoK_q`O
z^%w!$Oq+l>cNp{a7=;%plzBeY2`&4x&P?JvACmI+r5}my)J38T)lCaLMC0U<bfBDk
zEwMou56Sm!&6ojo3{GlYAS)Q{%`x>=Nj<TP!+3pIfJ>wy+MMnE{L0AQS@$?Q_Q1cZ
zl40mhdB^1eCb@8BbWa^E7N3P8;Ol}54hV|v*iI(Oq|_7>GFtdkW}_xxmxxbBfQL-r
zO4|1R{mxM%(t$sEHh5kCl6uLoJ}#iNkm_D(I$7o*N1Q#f&OLaPl6FknIY3w*9ik=!
zDIRUFV;tx*JpX$6CsCC88*;2<U;|MMj+p4vb_r$1I3QY$x=>SsE>SYPTXs)pw7oB0
z20AIzPE8Ai8M|Q9*ftlziA*zuD)UogCv&H*5mHrmR2fNlkTtpxi9WnO53YCPo+5y9
zp0M@y*cEMj;XJ=7no2<S#%!b<{=!|mB!Wr1ry-XOFZ{!GOub6Q!J2P-fDrin$$}UN
zS??_S?x-<OL?*AByduoU(NhOI2_5F8+T^9QE?<;_K`jtLN>oX(uH*pLIHfDlK^m5q
zreMY*LRY#BxR?N&ym`0~QF3D=sw@v`u1QkbQ#^7++<!k6@9b*IG(QSMG*$<?sV4y0
z2U3|dcoMMtG-MkP#>7F?73MhUeIPXp8?DW2^a_fyp^T;LLn)}jvFB)~d>g@bk067T
zG30Gvp80&!ia92kl3H%Y*JlR^4X`O?;0{-zZyZmk3WoIEWZmH`yZoBV1+OW)L~bLh
zh{|ib)vgAKO{N8+BuTqA#tCB@%V=HA-e62IaM)PNF{76Zk*mn68EzWo@+)<R)8-f@
zuarU}6J(5h-qS0Bv`H|ECnl$I5Kes+<!F8s^_-VfB@7u#zETQFnGiP_q{$qLoUIa~
z_AFUsWY6t&0fHi8L8R2M^VO1Cdprq{&Xjz%M%3T~@<7NgzDDPjOw@NJ>7jnQBDplk
z%2qOvKB|YJ_Y3Y>=ad7+DRF$h$XW?E#lFgF`zmE0o%Wirzp6fbMDopO#@Dss>x-a>
zn3Be&$s|cCqyu5RHo`iMlHHj_>;aF2;pYeswbV$L(9XF$*$bLxhTIRZ2CQucmZky_
z9f}-Xp4n%gz{;?O8Fsf?b$c26I?qBgZ(iF&Kve3EF4Aq_a-j!HMqq^;BNsTb{065R
zs+}HCK<PAEQQWAYDAuib1G40?#EHX)S(0lIs=_QHN)1v()Qd=IpaEz3p)nak+F^yf
zt%=Yg;Ol5`q~GtXE~P|b`~)lnR-e339Zx)<9vCPfZAWYaN~6haajgy|vt;vME4!f3
zS@oq@q@wV--?#<6rDimEFahDI94Ms+){)mx-XsPzTPhY_|ITLb*6>nUy7&W}E32ZV
zXIu!5p#Zl6e&sv^(tH{=y3gSGY=DV{0qu~V08p=XVJd7NERA+dP%~`IIa<mYDJc$t
z#ViFQ)H_-ukDc@(Qw<BroE7IyG7&wH9B!uGJsjkVi`gZP*5yWYGc#jLWY@BXP4b*2
zq+}p<jjBQHae4tpD(4yDDV$^{4GmS7h#Zk-wjb~hUtM;J48WE%_8>{ws2jx48n-lu
z0;WNoy=2dPz%TRzlRNlpt(Ze}DrQC40hQUb^AHPz)yb1E<t!8OWYThw(`YWTvWUAO
za?1CBhx!)222Zk#o=2Cl!0&oxJnBGY)>_pJRpk?r;FDa$e4K1AXHlaSZj|dm@pcu-
zdL@UTb&}`}t?Pm+1G?-&&_O1Y%7U|GM+1x5x3k!!c_NjG<uN2kJ`G}<Iht5GAP*<;
z-i{`UrocoZS>9jC3fP$ZRp5nfWqe6VQn49SM~MZM!k?UgSnCV~n+gmMbg1C987@D-
zr#W`QZom%hS<xb+ti$u_eCE>gc_@$fif06Lp}nvp;)5uOWB4K&2TfM_(&~$>E*w&-
zEEZ<##mZ)+n_LsNgg`7a+oM_DXrC*=acw+(JPdLw;6uldJGfkPrVZ-lLAzXbi#3$0
zA|yjoUQjwp?NM--^lTF=vqIBUS_^Pkl93p&$yc6ix^}O^^xo8iE+rU{9a)cEcO`dp
zjU`pJcj_Hkr<+b9-pAkU4JNdNb-@`<@4l0nEoI^}3D8n*%_=L))<U_*k>~6+SKw`{
zLMf4eq1=ICYnvvZd3g@;njL$=@@BTmaxB&Ov@96m45Btnd;#Bh9!K?xO^lA3v#PMi
zo_gNd#ykqS5r76MGdJOR;+DM2Bz;fTrf`{c7dMYbu)VXx_z&6x#I4P}<VQd$aNF=g
zFBxdV3Cc3)<q1f1$i&RZEI<9FUxZ5-h9QU+Sn%}#o2=RvdOk{2JQmg>9tX6F+Na_c
z)SD1{*DC3di-fHXN}}R&xO$W45^7oow=_)pMFQJ~eFwKcFX<;qPL*rTl{7%xKl*1C
z4%Nc%laDmK7;qx-Ir&nAIzYAHW)8JOG-djZ4r5(0Z5RT8j2F58EY1i2@z^=5)ieC+
zVI5r9;}=qAG&>s|&g@^<L~C&0rgG1ce?)hZuOIh(4pCl?))R)8!~?TWiCk(M%jSYV
zs;p9%(|hA2TO``P&Bhqp$<jcX392vBg_ya%0nD35OGR~_lbdK=R1&}Bl|8+EIs%}w
z*x*S>A%s_QLjxAaQMpi$m7Qqh1hEhc{3JR&hwRPLvRJDSYf!i+ZB=x!mb9f*6iTzG
z)Pdgm0HQd?>&)Kb_H47ObH^Z+q_*+vvV5rOL6?N^D`=)<k(!oP(2-3ak+h$tACo$T
zFH$-UMDiY{1g?T$e?Bjgox3aXz;sPB$u?a(GsChla1*|40w{Pa#ToipUht%@yf6{&
zdeX!Krd9o{_JWJ<wj;^gzDS|ANRj~?;Nlc<oAgo}jf`0YY>P=CoK9t)iWXIxi&5a^
zqson0RrM+XJUR0xc?i+EHxbMOu%P3$Vb<niQ**u-;6cd2J&Z{@Y$r%h^Uf@cldgqJ
z*DN(!RPLGnKygelxz$ZRipyCR8+w;<3=>0LpnXqj<=Y4vfm1uzTIChz!%QclN#qw_
z2Q6i22$>+V${ivf@-<`hgEkED_UF^@QG?dd4Q&{b$V54%_cNS)w%$=xmrMHHM}guC
zrmMuay-$i@)-8Yc&^_}7=q{r#FzAR{w}1c5kv5N=s#eVSo$nMcBies%-Mw$SnN2nw
zWj7Pi%&S{_aH~Ib(f3*Eo1MndN04-RiIodv&G?-KqRC?66+#7PdJ+?dilWHse8*GX
z9($Y+r@>(JN+n)ZW>tT>0NZYh+w*LpS{1Q-2Lerc=Z2Z8kt=_Y*A(k}=IhW~#^+16
zg}lS5ijK|j-(jDD60&pW-sH~H^b1z#mC8=1=I>6l(8UaNVYtyf!Nlm<+{u<=AKh9?
z<1g%&_LaSxU5B5@o1-e(Z)pedwPN(9*lZUgVV1);Cf+V3)ngw<d+}~@L_M%K`B3;9
z0rso<mSdQyM7-bBE`VmMIZ`QsGp6n>)0@a68S(o2Mjn3F^wsEIytK_|Uwk9F`R@~~
zYv}lT91b(g`RDd43$*i!DaL*<-}d^+p-(@J5o9x#_IJl6)tIx5cN>yeinFljsGh(v
zEEb!bEls7A$#f5-8BH!<ec)9}w9>BEi+g#SXbCfOx|`cr_mbo0Q4L`~$G^=W2ief3
zWGJR5hiXf)19&~aPQN;3c|pSG6_XHT9T+~|YDkXU)0#_BXB`hlFpD1uJFmV#wizGI
zexim6BD$ZC!X-_+L={c>7dC9T!_{aW?{L@a>!g6$S(X;6kWmD(6!~K232E<ZSM{^w
z!%H^1FZromZSjuiu}~gz{+XKQIsMdp`H6qQUTogQ9^JdR85XCFgf)H^Cl^D`2sgC`
z^8Z^t*N^Nhyx|O_*U?WDqcJVY?zZpj4@4JwvZiPF!`Kb`>k}nq^2+y&mZz3!S=wE$
ze+_|U${^)hfe_jzxUu3lpAiSK)?;hVw*A|sA$9<X5_ITO=s5ajcRqv02%|h5Rj#dJ
z532K%qWY@R2;X36g70Q<#(#P&#O14`kM<s)o-lV^mIDP({3<hpc>+ymo6i0`FE9DU
z3<k{~Tc!wvYFyz3wStJNCe%dKJ@W!41V<Th9QMcfW1rMc*Ru_Wk1edCd<}A&P375k
ztrBaS8T?ZUHEQ^e_9EPImeGVLMx5it;G1oz^oBgR7ah&?UEHnN&PJLAcaZN*PQH39
zR;FHU?|vdNQJ(qqYQW+s4OG%8T1rBKb|Xgj2wzsh(I+xsxGlRi!Cu1cH0owqgX5>@
zy<^3H4#AaM$@%_+NL%(a-kyGDeoyI6#4KzrZnqJak1xZD5rV;sk27KQCOpEh>o2<h
ztgb@Ta*i#<NuMp|!|<zL)+UQt38cx8YcoiCv*|)#J4PGB_n+;iSs{Kl3eCcPfolJ$
zJ)Ksq4`Gg=E)4`1=vw-+_xmX0>9z0Y#XdK==r3GQ4shhK(Q`g&8l3;}Yb5X>wKaOY
z9S!){SC71NzPa(m*8l7Kp%tQ{--{kWs;Qg7?vYb!&Aw$l_%+C&n(axy;cVYi!}$|W
zEmIwU9ZY_f!5-fMl?QL7Xc1q`D{xPKoG-0eYY#&UYh-3W$o7el>__=4+0W1R#>zJu
zO0jBCRRt!18L(+0OapvK1Pos$f8w(%e$r0+>jU5XR2(z@30>$>zMC>g4pq2|_c|AZ
za#hc)dHH<S{3V+EnM`I2T535fVco6lU--xWwKhBNrlqQuqWT*ucfT35&fk}ZX$!_8
z!qlRhxNd<u_61kg+iCa-_87x_@VdT5uYoqLU)F7Vw<zOn4@<o7<_jH677F9o64Tj#
zPzQdmO8K%rb!z8+L*=jca<hFui~Z4VPQMoX@7r64+ZyqBS>|`oXIm|P^wHXfvi#4-
z%{B3pPwFfuZHdxP$6xe!V~GeUzqa7uN8oBFQ`dbZy!`B^`qsOmt<6Y3<24dY%|t$Y
z_~jPux;*$*MeqEZQ)$}lf*1Ss^Nzu;1?cH@Yi_;R3#sJ$x~BX}jT^>I!Yq;_f#Sr!
zlMF?yBAw_+#UlLsafCAv5F3nFvc*$EsyS^&Z9{+^tn>(0)uar3yA7GkQe5G61uX*a
zl97QdA3gY|R>I|YH4@2HbQw28J-igH)gs*hoXh3PC86M`k$nluM59p80hM5E@c(+N
z*y?4_tPmfpA?hqR7OE@kgECZQ33qh`O{ywsBNq_JH&l>HN(BxKW2Qn)b#IV4eDR*l
zcY&6=bA<U^5Bcv$M$Rrjc7GMV9_>ebaZp8GHZiSNk9CT#`X8gviG-NyM++9Bv6o%<
zGRjAWC#j4FMjotDO7Dw+sf`v?L4J4#NI0c<0}1vz@h8TKE|XF`1BBlx<ea*!B5oj5
zyGb1=>pAxugKU|yRIBl_1lrEK8rk~bN<)<MC2qR=)l98f)ctL0Ow^n!+b&&bNhIyf
zz7fKwEVKi%WB^X~X7!(MeT-QO%Sja>bSj=xb1Gu=SD5$a&0QNR`8Ry&<Y9VoaFSCX
zs_$I^H;9_t=x7kF1CiwInu5jRJIz$wZQoc}V_AJhvqq2#En$NI6>Go?XthUKiyP4{
zk@;6>%oTR0a||F1fByfX-KY`Q!ukARVHC<oGHSq-Ii<)LE5@?1x_FIjHo1{8r%CM*
zfH@!#hFZjPGIu}ET8WgZDq=msn)Lv=c7QtO4C$4)kjN7D;aOpsZDq(HGtY6>4eKxJ
zAF)Iv_AG1!f&zZ5hd1KTh~BRfvEL$8su;ZmCqLPVU)TrUp}67v0VrjmFp4X5W9*!R
z0W%CV@?Zs2yys+z_xfO*dS^2BhEZPL#Es3*2hSk2t5N!55N<gfjF7EgsbSnRyCuc=
zh0>_?m4bRnC@6lS(?UBQT7sz>W@se6APi+-fCUVUO<q)<T9p0ZWwv9ibc#-p@?1vq
z2+hxlX3*#%;2(eHnwLa&&LE7VRZPQ@z-Xdr%9wk@(yP|Q&1#uw7%`PA%D#{ZpTOr?
zDoren5H6Ry5ZC3Wec+GJRSZBc!8VKms;awyA&6--UaujSNnGhL3W-lzy*v642I(*Z
z-8Vq7h8!)sW4Dy9M`mW$n-czlF=suW9}L(3H`OX)MJyeO*^{hT4@gplJ!^qBgNCvh
z8P(9>*u<)W)%Lze`Pde95+k*W-3C=(m5o8>v4x}^_S0$C2V3H}t+&*CF8C_8o(UlU
zEcHvXaalmoFasrj957^8woD0m8rh+8@U6C=nW6GuPK9>161rYGI(;C|0P%2F$l%uR
z*AFl(T4IT=*y<s@rNr~S#6kd=vFWZ48X>UDB!l!>$^W+_#`iz)=WuT}`D_SmD))^(
z`$rG?yPfEU?(h#so!`&st3RWGA(~dkGvFzefQ90?oIK=Zb+H)bXu*z`uUAe_H{b-q
z;WswrJp9Eu;`lMNE?uTsTvgiER$>ut_nWa8L&f67M6U~$n6MVR?O9sGwbNchJ?*Sv
zHk)FR+f@KwQNzUUtnJBw$6Dt`(B#}(;1b7TB5|j)OBv;ltYf-sj=g%Yu+h!S*s6^q
z`|~?&6dK#Bb2ttK@twy&D6v!KN^nGR(Gt}qdihEol5pPS*__guZ4Q~CHy6(r7z{rN
zA!GwD;z<c15DdY9gCIy!&l|=k(A&tRLL@7#BR6M%9|D}1SYC;>6<*aI$*~nkT^v(#
z)q@qHnFAZC2bc0SPaiv~&IBx*o&RJ}ufu=EKjHwzKs{oYav7U6MU3i*M>OJ5gqX87
z_}ElqE>QML?E01LH9&h8+%(^^gHi2EOw~{*wmWLce*||?WX>mAnhd)Sr_rHi(Q0!&
zng<tlk43gxGb~+EN}=fBiF%#lcTb2UNNo#6<?l%~s>G#G+0z!Wm%0zKzf}6mZge|3
zL~RC*&iD55YLrR~7wP3-^8$IgM!L*IP%wAaTaUd)2dMe+Gz7=;!vhqKLkW3cvQ+&_
zB|M#KJ?hli`iS!+pjbKyahI5e--{8b5BJxi4tzZA?tK`3w4dn|>BxDe7S@y97{c>n
zAbr32E3e_JuV?#K!Y196#6B^MY~IJy#wU{Jlzw@(O>AJk-=#wIr}(vaO20{_>|vY_
z0ti<|xC7MsWNlIdf8>5`V7ir{Y{r)e{pbNBYFTxav;a9|0~O3Gswd^&qPi4-Uo#qo
zJGG&h|12<%cMu*QRA!jCDR2!gH61hpDW`A+)H*C0nZ!QYF37O@D*h6{yY*$CcpoK2
zc{BHtAED%qy~KOX?}T}0R1{x@lktk8V#&^4U4P<QBO@=ZS!s+nvDN6**qWABQLou<
zYc*O!H;nC)F=vcDMHBy1hp~}4XUu|HHtgm~xXj6wfSBw-_%Y^9_^E4tFm|e3R-TJu
z+~lKT&#6^3`GVZO_1B&UeH4RJLvFC!|ILyX{7+;?&G364{=rPT?Ou&~LG0ePzh9>L
zd4pkW@C-m}XR}1zc;HE<tk)F=u#<#8hgs3sEU2FcP}VSu{rGZ3Aj#*CN#a0$J^5K?
zUr$l4^HuS)*Dg=(R?wR3MudOYUecXOe6tf93}j7@i}y08oEbue+Qdc(zOsaf>B896
zh`h;3a%9e+J;;ctQ0Bi)UY}XNuvdfPUVPro?<E8Hrc^8?@umO<vBWT~`v`gT7m3V+
zM(CVUy0r2o{P@kZe=$p-$H0va^HBKrQ^tL1@|S+$>vPC|rhF7$A?K>L9-l~#-@t)$
z>&U`5SakS}`KS<Omlhn~Y#85hi%6yA+U=os?l(x$RDJQScKVfDZnlZ9F@++W4yJGH
zL|iBkG)OnKQqtWdip89xq~Z~FHL$r6S-Lp7A~JV+Lp=OE{h9jKsqy#ma=4PL5#DjX
zQN8@$v<0))nIvX)6fU?5xtsLG+XHh#H#ml{5<;NJFti?dg#0FF^3zW|VLrIq)4c_*
zxaq_m5&a1EKI{zNBkC9p{FrFJi-C5Vm<<$qX8iuZm~?x&WE`EN_~h;fAJ`*H`xpQ-
zhZtj9W6%nl@+?d<)0`4y__ryTPH=@l0*)X_OyEF0(EY$4Pc@MrAU}FVFg4`BG^*`M
zruxwBgotX$<L{|TcApb^3POgTA&M!2NpykP1FpGcFczfm3sRgQ+ZHSVVS)u05C>2T
zgUgkgbuX)`BwfaQ1^YNL%z(Gegyjf1D;<;f&uTG{><|B3VNNna{jJYSw7{pCAT$Tp
zf;YM{(9VZJ@2MCg*YjXR_-ko*t_h6DMqw68WiN?>%p%rHK+vd4Hj?va7TA=+)D=L0
zoN(*n@f4sG#DHKLX-xlonqiALcIS|40`u48NXH2HsC{g7@<iMz<E7GxbiD=xrW?im
zoC2jjKiW6rt-EMY$tf0}W|7UF>R6&6<E+pg#eBXcXS>MC4fYwrvQI>e1l+4)HAbIw
zRacesnPMmP@@h$2wDxCfE2LdQcCXAppaw3;pkIQIBU_lLcB}nv&U2e)!<0Jzm5e1M
z)#E8<`o+&_j6v>ot{4Ur@em9y@(unm1*EK9)95odoA!xi<OCIq2tLh&7VP;{ZV^5R
z-1GzAeAtTY>I|21(EAKcyi)&&B`L!Z=phkY-rvpPbkL||8c7%{?+ItY1ka<OyMo!s
z%<RYE-yW*HWGVp&T;i)&q_ev#ClvPBm!gRJ`2<mr9u<UL$7Xz|6q?XsQ6XGR?hd(V
z&-yg3B&JbmbW-7m#EdJX>WE4lm-Ppte+E7ge-QQ4`Rib+!A8P|*;T--GlS;nb+Wkr
zebQn<Qld7;Pi7d+F2?wves>u>1cCGFE(g@o9R7C8!ZEZrbelhCEbZY+J3TUQiPl%H
zh{jmc5-ThC8^BZsi9c0viC^|X5+e+2I2fwro7R)kL)%mQj-Hu=Z@1Nj_XX4PZFK`2
zDYrU#JGmOAZ&Ljm+Z|#~<z~u;^KXS|r#F(luLb}MZ%C6H+A2$pWjG)YisGPHW%Fsm
z3Y~@k{hJRPpmsM<<e(urPEc<aV8DXxW2Ax^;>QX1Y9tIUqk36`rG9BU6e`bk16m4U
zX$0$&r1&8dj9`r_$BafKkzEEK3J4mo?3N(qOTCfkfm*rzmh`Evg&1%~pA)52JxxUN
z3g#w$73T24Vj>pVp+SEKy{!~MjhSApc#b+g6O2~x=I{qZ^)@V7j6Yg5cn+w+EI&@#
zFAf_)aV0$ZQO>yK4fCaG!g7$MLzA_yvGDyP$+v~|OIOUySH_r4Cb_b?prOEDAN|gY
z?z8m8gnviu6Cz;+#J&a+ToV1rA$Cq}D&avPh;ZYxv`qs>xenM~^6E}CbrUe{={rou
z0)1QDJobf_nV3;xda>Ng-yn?)(OQ7YEQK~maJ?CHP7*oQ9Sz8wM@5BwrovZZ!hWfW
zFYANkCx#mJZV*psrNU<DCj)KNGAV1G8&t5FTu#(JyL1i^xUsgtTz^2V<O+=&>*X?7
z8w7+OH@fi~L{${e?f3jskl~{VbPIQGWgrVRmcm9rm^kzWqG*btWWG$Ss8C1-o26Kb
z+jdET3K7#oEjcKCFOHT0HhuV0oc=fbU+_OAh>xfcdfh}xC$Hzb7=j#XsXpeS@U(cY
zt8r;8XYj)??J3<+K0;f?{IW2=(LW1hc)5D05jFqMa+4b_hJRaol{L=|6W;Zfi<&!T
zaPs^<2Igo7Oh+o-NQ=#Lh3Z9vE>e;r24miMY3}2-?o0i`FGxjHuoDE%@mEw3h!AjT
zC4Vt|BEjeV8w}(abkWVDg2OrVjWuj#ws%kYGHuQ)t$8lF3T*L3JD85V=6s(Rw8GwZ
zBS{aV-X9;l8kvyW(2`#fnfbf+9vfHeVA?$1OR{HP?^7Y+T_5ND(%?SYmz?bsFFHm~
z$p3=>iFjwFd5(7{JH{2XRRF{Bg%_u~lQ-I0Dho3C0bSEBUH%&xiZpXeo(A|bgwGZ>
z*Et0#AQVX;EhS_Ten;CwghSi(1NB8?aAgS8pe8BiXnH{XpUMS;DjL^Krk2^s13O?$
zOfZcVodUHFz|jCm<!pd%=#YzZ3Po$KU5h=#W~`gShzv$s-BiY*NaGQx|2N7Q_#PQ?
z9#QDq2(XMxXreip5*Fc7(VZXBnh#_n;HEqy{!l^a&|ZXMHQQb_Z*Ld^l`Cch(sllz
zC)ro1RG29Vn#x4gDq5j%G-hf5XtiCkPGx`D3xz|3>xQ+d4!!xQFx_DeA{*>J-DeXc
z9o&VcS{sge8QK8MbL=T_Zt#bse-kaFMI>>anYX}kW;F%x|AAksjCAJWqSGqxC2d<w
zZ!uRRq}}w}(Q3#swpv7O_(mYPtCi|2r47PxK1JbvhoHh;`0eMAK;rh<w@}DA-RLa_
z>{a7>;}(gG$TT1V&Jv4`K%w-NGJ20m&(bTKbTHAJlJ{(V@^4^RT<W8kfU5}wMK}Vl
z!(CkDOPA?_@hQ%TYUOvNguq`1OWde2)stCZkf{RoEJhu)(+dfH%}CZp?M(1d3(BHX
zalDZaoEvxpZWq6n%0jVD!z%ZB4S3X1mr;+Ep0NbU4FVliGyN>VsPo$BL8J!px>9#H
zQaSBBDYm44EH+_a81RSlA;&ymHEZjHbenQs9v$(vzpgrt4_%SbsoH>uPN7=*L&>@{
zg}Uw$Lj<~*-?BgLJE%Z^u3kXN{YDvt*svnt7LfB;7boYk45EqmRfEw;;;G0eoxKPh
zO3c+9MYlG=4*6jN!VtgqkhmbADr|K#Kae+{78{cSyrywco&ttS+rzA|E<v6IT9+G8
zqYBR=m%h1Q7sFo_yGB+(07rlq;1d1U<;GsgXyfzo(ANygQL&qDldg13j5nxOgz>Fr
zI8D|R123G1B_&3|_Y{+ZH^^(k&2h)rB|xywCQJ-Mgi}M17}*I_=~)bwhnDxPgpg{n
zNy(@iHKU<+Nu1o%`bUn2{&XBpk)V3a7D!t2+TQO|Rxr4~?oN<~%sx`uMl<?e(GF(b
z84*4E^?qd1c|SVUfc-~D?;V_14rdCbp!*6z;itRiFb>a=jvj+Xi^X9-;_PB2d+M5!
zas?pwNCcv#c^t|aJ>TS>FRpwy`$L*tN6l6vr@E+)gNM802Mm5`b*GZ$Ydaqg^h0Xi
z$(hK~u~C+xsS-QqF~bXQXQCg8?sedwR`2dYz1kPx;_F`Kggzn8rr(XEM+fnBQo&&;
z@4~DUc_CXK0@ghbLC-{Zt>I>6CNwRjf!8Mqfyap*Gt|QLYvphU%mcz56b>|R!g_{#
z=@c&g0#S|}GeG6|e%0emh}!?UilEIi#s$iJ8n&TrQzkXQ*Ch=7egb3KzYnebU;eZC
z36FVqZYHAY$<b@sLi};<W)s`gs+s>@r>-77^zhjd#Tn&doMgaqVG$=wdE_gHxfF&3
zQU+23>l)UY%Tt?kSRE0C1%r?w`&Uw=5&@e5peiIMOCJ`NzB3x5YH!a5A!eka;`(5C
zi_dGvy%FreIpNoaUv}Hc_`t5k*hkNi`}gvqTG1(E6bUqK5#)P;j#n+{RF}IDdH+|Y
zXf32ZMAfhk!)+Pf$&r9TFmEGLym+kQ^lZyTiDX41<-eRlqz<xMEcGnp-uDdV_^+SU
z7rr=nH2b;YZW+4&U1R!qKinJK;O6oEjP0qyUKHxOI`me=OO$&+f#yBKrudI}IfFTU
zNPi~zL=Wh;z;szYS6pcgg<iZ4ioDG@`Dc<Iu)CTl^O*#1&24o}?(x~m17y^pgNc^?
zBRh=~qH3V^Cn7U4awTP+(VBfQtymNQ!%Hs-aeb8<u#squv?C^HN3_;*ibQHvr-v_=
z<*Q~)Z(<csMkR+;o&d;O*K1;(AAheJa6s?HJ(YZ9(01gQ()>8_dZ|ZbRoc{e-6R=u
zV;M-ib|LScyK50G<q-TNy+*$Xp9-7Zy19`(R^Pul1o1}k;scx%n|n<PbQ*%4MU*=h
z;Mc1YP%*Ep<QIL2;@At6dc2IPlLoZ1g>Xr&?ooyTnXf4k;IDMqEB+WJd;y)8hq4Ky
zzc>2b4uit#U_xjHikA2JUC)I^Kc6)tJ|?~Uw4Pef%8++;WB2X~sU^|~s&@US7pDC$
zE(FSqBI<|{q#}AW0;tSOL&lc2h6vTT$3|g=UCMl1(|$x^Mr@b5Jv2OVeAG@bKUi_=
z_A!$9k@xYKu%?o08(H>~K+s2(VEwVg(Q!nZ+DH4a)-8EDoHcD{CO`D8?=sxN5l-4e
z^7nH>DL7KN-YI5H_ckOw8>^AqwCplXI-xH7_k4EWq)*crc$3E}b0Vz)cv{|ZyGbV0
zo?qhbT4>;U-Uf#4{_pR@KbauEdB#8J!K)&*FXUzDs`z*5-|BaN_@G6f55o;fJ>=<P
zHNw9zjY4xT{Wl-(rOad>t}w?HTzKBC^vUfPn8lVJc`7|X-w=&y6!)Dw`=FWll1{5E
zlD7Q`H6X<YvvI{k$B$AMG2w#kxY8qrxT66JOSrgT$YR=TFqPR^jLcX4Fq3^CO{Pg+
z1fBZ?HK_g`w5^;!1cq0NpqWKY!deDq>a%pRf`RF%qria8b=W#g$mjSBoLP45nH$xF
zV)>E_63X_{ekmelh$LWUQlyl*5M&EA`uJ&#wt?7_;&EeP50>T@anULgD05YcE1uh?
z3+Nc-<!I^^<ejX(u{nYbpenMlm)DJB-nBt05$yx%P?f1NofHfMSqZH1{P13i@hF%A
z5920Rm@D^`fW<=$vH3qei1rMJx(L-lI4c+wc|%K6v(hBVvp081qM7{!td#;|aD_ZL
zs*#noa`DUj%qUB@9(-QrBZT_oYSbgt8rvPt54QB2-loclWr5ChM49ppLN=)8kA$&5
zsG@}!T@$m}gJ3_ULL1i9l#Z|-^BN)!7iX5s5q)}<lx4CWaYy10%}yKb0W~JtDMuq$
zIA28}SO7>7vsXZOQzW1$00^Vs?Nxb)+eWjP^sJW6TiKxE@b7>q5|GQkmrw39y<mk)
z(C!#PB&1sEd!`SKtQJjiy4RB8=8B~wk6he09qLlCx<a+TxeS)vsY55Ah6hh%d3=VA
zL_Ir73I<S>m{tsn0BA`jGCwAK^2mq4>cZ5+oFBzG?SYFU5O*~S`*T!4G$ao|V?Q4D
z<o&aU-uJ}pb)R~m)AQidAD8$1&G5mG34bSg=p3ZufZI-Jl|8GP_~l-q3@^PP-gd=T
zk|XjUuw^wT79L6}dhVQtTVgG%c&Nq$N-IjP(}p)CtDiF4W&ew~)BgZGK*PV+WhnB$
z!W?%KqLbb2Xsh@RCv)HdRX0>Iy*4xZ6St7u$$*dD>uvVqZn2$0w+9+`JMhh3y5*1;
zgM!wI?ju+5LqQA}-(7wN0neBUTQDhmP!*Idr;Jp%rsCZSP<>?$#0Ls8r`F9c$M4$!
za<4OANs+x=^sX86h91}OWDWR<4elUW7AI<cjpYI8Bg{A2zT9ljr$w*Jo8gA>CY}~J
z@Ud!#wQ(1Cdhzciw)w!V?kP$Qt~H8{O*MuFl+i(n*>5<>uL}uD9{$eKR%*o&)2~Y)
zs;pje5-s{dQGW@$WnLd%Rfe}2vV#=*5t#4CjfOT;5k=fjNDPp?A|>{v2|lHIDC@=V
z00v?-a-xu^HYEn%2NT*(T&mMsKP>1L<z2IIR9n#x!P`ig{77s9^t?hou@UGE^)|4T
zLkK*!xH8&r+MI3vtuUS!ULy(zxg`P5^_cFxV!lg_u)vuteXp!=MF~>_<WfT+3#Eh<
zjhWg=np7x;i7FNFU=t#d=;thu<><`2hBHfFXLZ(<N1OnQh&uzjv!7gm;`zvO0raN{
zn9`33xSS<7oI0`xvFb;uTPUvVWrtU99GdjZB<I;AwYAO&sR3=&dh4*7FqUBplq`k;
zZJc9ZfXE)m(a|>MXk>Ch%Ew+*K0>ghY%ijnr6Uh4w?v*)SKJ|AByD>ik-dnJv(~J`
zg~HL~{zGanDZIVY3y}@hW)rQKv5Xu5kaJSi!0GSM?kyO~cnPW%7aM>17vPIbaLaYD
z^1~gt`%ZdwZAzDG-QSqv{JCO&eWO5Me(BVSt1q6+>eTv0zBK-gDPDZx#Hs5qpVnjN
zwn~MK^}?Anfg0geiFBFpjB$gOx(l%{h?p_8{HYCB>Gz}9X0D%Na`KHjmCZ)`$8reC
z4;dlvQVeVZe%V}Q6#h%E<D^EmZpLwYN`BG3y^C5+6)OcPHVjJ33{?oAxgiQp*OO^#
zn;KEzTm;GSGx<h5B<5)h0p_kK6Tzx{2T6TP-hiZf+WChK<Tc0zyd-arrDYGJDN~er
zv4Tr4ue;-gMjMa$y3P%5xU1fEc;JdxP6er-G6CB2p4>=Ls;A%V3eRuK<1YvTkL8J%
z1Q1609%*+<d7%r}Lx2hYGaYP1PMfV<qeC3*EwHzNF@5}p1odOZj+y?M9vGh|sp8eh
zd7&~G5C#Q5VBE!K53GlLtj1kG6%Y7XvGYzU%vVD_o(=m&w*K}@_WEL+ko_g2pE$_n
zp^Pl1mRW<`1S2<zPs6gA10aiI6)fyrS$o_GLP1D<!%)nxvo0_*^PBDx!PD4Qf`mtM
zkJgv3J*0uKCu|=8HLOTv(~V)_f$k-{##YNGKY;V$g0g1S`hSUnCarQQ1S`#05)<Us
zPbY9IEy+!5*zU7h0i_jPO|FRlBQt`EI3;WV$D=eJ_(zmI#SlfF8}Z%$#+UuK`6$G)
zw+3CscH}^lI0UOt*h`#@niFfPCCM4=H^Dat`BlrypZT4NLH>UmPO(2l_X#-j!41wd
z7op7zav2has-8p`yUb!8#<IzjpoY%wB5)xLr>YsK{0SF@Ky>|bYaps{_Uc1_Q8bw;
zz8<Ks{PJ($AYltj**1}x*tHPgzg}PNk^?r8RI|IJMJ9T`-Pg9Ak*<sU_D|GyA_teC
zwEvqp0sl+p#|ciJuyB5@szXxwmGpLzv!-H^y7PC_YFnvKtGS-kbjwGBjQnaD)a1bZ
zH;FCOO&CJn;sKMHQY|twRyddCtQ5UR^Z{X+OsD<l?<36;`^56KK}X3F5ur!I7!ZY~
z1Rb<!%Mz62fF^W74FaTY(9<ZhE#qYohhLj6DP=7USh3_gve`gvKr<Fz-{E#x{TYb)
z1J{V!3eQNYpZZZ75T@W;6F$f2^am5mvG;Q4gnBG6UAKCH%+LoX9kNaj-N(eD0@Cr_
zLkPR`tvN&1`<3qY!K-w^Gcy5{dlG`;03BkQM-&5lX<n_WR@BSQ0v$sZfsC$l!94vX
zQHF|!TuWJ)ff=2;4)pZChm7%Hcm5*@RnV;T$QKD^ptr2I;eh3Tkef|Q!}+kcKq<{q
z<9Y4fUw`!@oZ;my?DtQ0Htz&_CV_o#aNoBQnp$<-KFS&cF=r-dAV^pu6&O}w!GCZz
zd_IINQ0Z8RE~jxYJ+G9Xz4};fu=Hg~Whwu6SN90KdLOlE$54h7{57(X2sR(&8N^5+
z9l+W;*)@lF>KXjxp0&eTKY(XLTDR~XE4j}|dY~a+2ymaM7*o&|R>8YCsI-=H0Yl8W
za}ldIc3yZ4Y(RrZfq)|f){XiwZ#0>@d@U~c?s?b@(y$>TvR=O^Obe4q(lgV7JTe_%
zl40j(Ebg>Vs#i6W=*pNeHO0QLriMn-()6cA_KL0Wh=Rbx<RZ5_9{{E(>@i+A1RlbZ
zrpi71_qp0VNmRfp0y(cw4EkBu=pKI4Z3CBcQVTx9=WV+b94wq_P*XC&S$u2yR-Q#Q
zsBcNW4M^rAH*F}1dZgV>6=05!FD5!`?rpbOMN6azJpOY<+WWkkCe^JZv(vgFS=O&%
zU+ObQ+72&3F5=|KfSpedvs1%_HucsJzK?VH!=&Yuh>mRHwPL{)f|z%UAade8>4AW4
zuIzP4;VQ4n>k6c(8Om|z9ZAIYIlhs9zh+KmWjrV#m%yIRM(}RJg=GJ2EHm@HLtW(V
zY<rt<8_YN6In#M=(1K*O;zj125d9m@ozpK#a%UIjxqWwjV)3zU%84`C*IfHd4!Nl_
zb1%lX)*_cIKtK+LpwE*4-Jqn}a}@H_LlW9vVb&$tO~0-)N9XR$*S4%O2PC|nh7+5w
zIt*%60L}00)**(5)62Pftj+xzXs$TASTNH+qi5hl@t^#SQgpoQ4?6$t-s;Cqg3YW%
zGFCvA_+u@LRNQgotWut~W%e&efgCq7b^u;jZ9`CU9zj)r>LfWt+!dB3$k)92w)ZG_
z#y_uYV-|;+5mhN2$<HA$2XA>p%pGwAziSPT|Hu{%-J*y44_P@~_0WpzMja%8HU&uh
zboirp4Qeuiih-$omOVXLUo!G9l0uH)7Pfjv8MsgTR9ziyl=jiynFs5>Mn?5cJ9pw&
zsoL)Nx;Ea<z=yA>?sRasv0nd?98^B8es8LeO8%x!1LOHQ76wNo)vo}{QS2{jjZBH8
zdYN9ANS3RvtEd3{5^_7FeozWQTYQ7mFjz!DFl|c7&VSL+DbfV!kC;G<=b4O_k<=MJ
zJp%u2^7`z~aeSC>kCMW+P2XX&`!OZv0s}^s@|g-T){*?O{#$lp{m|gCbtNfO-o2m?
zl!f58nw|JgOy&bvfg!gE2}_T9klwzMEtJ)^z0SQA#qxeO=evQd7$hTW1SMlx*rZdU
zfsHDIy&2Gcw||zQ+a0|=nRMxE6e(kCAV{i=C=f66_Fj+dK#ZMZ^F;N4uADjIbm0b<
zn_QFDLTF?L7vx$gTO<;apd6_WGv6!t%}n~kWcq&MPGsNm*?roZN;_`@FO$AM;s);u
z+T4?jtg){m?SHQyru|Sp+x%M&{I-In<lhlEDb8Iesw%iBS{2A&F?ze7s^oY0KIUt&
zD9&;pP!wK}zGipR^2_ociea&vNzUpWqMUi!(hVZVC4&)(44<~YesT1IInndw8NlGd
zxQSm2LG?lxbtwZk$X`EojLU<2cTwEg!TjMCc>Bjf`<rimC;=f>m7VXt<JWJ4w^F?b
zAvU@VaOfcZ8D#Bj4ER@o^IbvHx0FuKy6Cpnaf@?;ZD&i_|71Q^2k{=@;%W6Spl_2k
z8y_01k<gC$JM#4?-KOc(l6#An;jower*5fY@{z4<i%yz0n4AfvD<nN7ERpw!%R}~$
zi0@}gKDa_*p^<rs`ikpm2PPh8mvz4u?Dc<*DZP#Y`aCr+7~Cla@irt$P$s7yK^-;u
z{7>}^v8^Jn=QVqraxXlkPk^e^!l8J0Nc`=Vfj0>MP);woVI+cy*BNglZQ7t_R#9ZG
zT%04OS`*8;9=uVxRJO4NXjKrghzo6Jk&Z%xZN>Hdx*yWN1?%3gCD=wc15VhU-Je^c
zPHVKX8rmDml96UWY7*h-pr3VuI_>gv1G5hQh8a6K6cmGRk@w?XbX#upEyVfeX?(sx
z-SZogbjqN1b1Sw`WE=GX#+a?LiWiG{;H*{*y6NZwf=?z6Np9E&*2p3gB6^-=51)%W
z7B8#Jz<4aEZExL76y|Al<r_T)O(iyglM806e8cfB+(YSNB3*MbxotC}U218f8W3x{
zKok>Io?4wHCiT+9gOo%8JUjo09vPL5u}hY23LQ0QhSFV0;~<8n$VhXYX}urvdwoi_
z@zg%c(vEcJxq+j!Y#+{i`ghFJd?KFP#V&oKd7UNc*WA-iY&(E`bV!}vd`*z}p-qf$
z=kC2PeaBDFC##lTHt6T^C?BsHa@k}*hzG*Al{QYAOc4VlnutiGruB_tP^cm_=&uhO
zZOlz8y&lOol>ZF<Fe-hL!y)O4!KeGNg~hwRB77ra=|#hK@E$1CRDh14+PQs?**5zz
za>Sj`ob*+A@bZfqxuYiX-5Widrw#Wk&<M=&EJI(oeHxz^33)syS2o%EhU2@QNz4i<
z58B9x2ihK5{6kgTQ3E<}U&z88+3EWJP@CLu%uX?duT%=vn+r9vY%$0rtX62|f|EH&
zt~4e%_qiWNR=r8jC_T$CfIjm=H5(RIU>RJc-O~&kNx*i!HRF2-WSDvY*8&IG4`W7E
zM5TmdRvHwT{<QOZmzuE?n$_NaHc!aCL?w3-@X7RMu#vek_=g#*2&rHO{=|J8qgRV*
z#wm5ld8&Vx4gnm?{~k)Jpo7Q1Xs9hDpfdFysSh=2{>|={tvArjYoWCrOkKQYt3H*%
z{V(1SwU?s!)1}%W0o8z7ke*|97b!WPl*5LJtXzr3AJnJV>f_=p<heUUS3P{wt(%?n
zjwU)PFb*h#bdfWe_s#|2gmlT3Q(KT|uHa$J{Nz;rJhRT)xn|Bhmd5r<zjr3t)L579
z@z5mZeNN*ui4)|co?_CAmPu8{)w|rMBF+|*w<Ka1lFS%a07be*X4FE=BPOFuAqUXS
zUSyFYm?$6#AxTq;!Bj~+ci;x;O4Ku|Uz*aqRQRt?`P=<X^rjaotFGkl$af>i7Z2bN
z&J89(5v{i#JJ8+Y%*PMum_1oX_lmba>E5M4bf0;=#_<}HX1}O=cLm=stUY8Ot$vDW
z>HvJ}MU+UPlxeXt?y=IcCh-D=HZB}?vtunK_EGWf2WMxS@d>T439PI(TY8z0{gco)
zuDb9ESWZ5@NG*t{uIw>qq+C<KfIa4?iDS#oU9@<)q_Zc`;1Ej$C-bBh7uwup6-?2W
zB-JmY??Q25X9W~LVGgCZNl<1GiPMMmYetby-Ls~AHEa;vy?mH$ji!OZ6pttj)v9j@
zQ6OW=AFV$6#CBfeLYuQJGgMM-e>|TT1I?*j_~sTP)kPqlUw4Wo8FTQdG~u?u&#-7#
zU^8a|hxFaHo_LWG*bkRJ-tA*j$MDy@-fX#l|HvuF&NOV>?1gmk%qL6c&wU-`2nMIg
zuY>4f;*D{vt(nOgQ;sbSd}sAjDJFCjAOFFq`T@v_m28DGZwQCtja|$*rZ#hJ1*k;V
zyWk>Cwrq4cO<a|TYpS9d>1#?Dc&$fWxprZADT&|kIrdph(f^Mu*PulWmNh!h_z#1#
z608m;^AZyhNppLWvY@Cn1<$FQVd{dRRtDjHRZ9jrWy<~jBOmk9q|`=WtavKD=n^Xt
zD_hc7Wa{?6xf){^;)Gz(vH^-5W(KBIbTx?lD+ISO(KB4=CHMu<y37?$?Xtd^0)QOe
z5W34v_Z}eXPMKFl4pxI$zP{<W4PmN%|3BaW0InsEs~4H7>oBc0??2ZvnsBG<aEziI
zq<b~u707-mUbtlNTK?)Qc9Hlwy|+dYZh7cXthZpx-wYo+$vTbn+c+p#@;|F*msi-h
z5vj~!%V|zOs_5nI(^LB&un7L3&H`f_-_e+X<%e(>JdDX52p8Qc2Va?fxaO&w3VD9m
zgaYaEteK)$q%xJfIF8_3VYC~L2QJKtLuygNiSfhZRbnWzV4)ML#L|lY0w6$Nmx*MR
z5lR~sVAGnC^Bt*qZS|Z%91GcIbj9Ema-O>CENCUC%<+1hRe!?VrgpEL|GLg2>fQE|
z61iM}UGbuMi6J~|CW(f4=7eR$9dQ_?5BV|K78$z;nq1C*U>7h|Y&^c+lWdqj{<PU{
zBQC$ps-7F5XxN5aVj;Bq_xcuF!iNls(cssT!)dp%8FUxKiexh~?%Q>UTATVw^ElhU
zcG@49FXRYq<@|S_<45TqKhA{dTy^tSW5>w3QJr@bH&-z9H~~qCYE0m}!kr7xwQPnd
zAkWS(1Zwco7$rlQn`9|a(V*s{t1L9p+PpsI3GOPGGzLk=4bHxxPHTt(z(RJq078w$
z0<n*c8!dDYCKng^@+IV<hmYQKwCLbEgbiP*vTx?3X%Q7X&(0?_&*5HU&!O+S&+R3u
zptwN3ez9y6zO8%X)X@i~j``2Y8{VJ(9vXe2Aq)*-H8^QtqVucKpkyD$kKP~S?jf!~
zvNa-yG+OcsGs6Nw7cYTDLLiSuodpj${{mV2SG#cS>aLt*?eCM8TbN@y>v%+4baqH*
z?K}*)3j;x}8*pzGT;%X&X-ELstAu%GIO^uYPo$ec7_YGACoJE0pMx_C3_i=)NJ6QJ
zzZ!$!zutQnKTvr_7oXk`{COrOA<DV@k{0s>Ct0l^IMOJS`Cf)O=+fKfI-X-!a2Crl
zEhd~~PsqP}n%ajDVRab!ql48LCD}fyO7*iS6V0or80;M-`uN?@Z$c5agBAZ&Z`iPR
zXyQH|QR*DwR=`#3^6lU&1!OVX&j?rg+%*VherKO%Az!0m#P?~<GTcpk6s617rr$+9
zdHw6;`5*TYFCRlZe)Y;9eUX!;8vP3M*F(NG@@qoPzSCPeXO5Q4U!7ZFXi%rX^`4rM
z#7x#M2sl}bqKE^M^mEMkm6Nw`p1zGwx6T%6vu(XiMYnL>z>uMaPAl%RhsW4Jr>a5z
zid3%nZM=B<Y)i;YG)F+UDWrL)xvl03gApWe)dTQ*BaS!WdU)PUOQp25(T_}%q;Vtv
zB<K+jdw$C^rDCS3rJe;bag*m;(dFJ+V)!T4n-@<NHl{L|8CvOM*QYV%kjZy0{4w$^
z!oim9h)QU2uzug&I|rRS70(}3ZG_c3PQTpvHTdUkm&yXrU|lpue;&Ly#=BoiA6xBO
zCu^Nfy=xBTC}~J2t0+z+X|)s!<$V<le<6JlMp<|CytV56!(RAW`r~N2{D|K2V<!0^
z5TsI`P;1b33IOSrJT{i{$Vo1BJPDTfF0>(mja#Q=sz<A&3)?Y<e+TV#w7Mkm|3lYx
zL{)7*Mb+dS(nqKWeRo1oH8+^#`&m+~L-Sv&$?c7BvwoDEINu;IU;9=3#&4oG@9IPr
z=JUjm04@^^b<m*5@5UC(lJUW`Ke*v_`c#iG#t}<g{Dr;}pH=Z&nqr_~XzIpw={Nlo
zOGP5WZ%(qv^g=t0t&^=MJrpKsw<F-yY6R6wo;!3O$t)zgr)pT|BpEWw4Ndkbr+4ke
zsJDs{ovMQnX5SJA-S@$K!~vX6?h!HQF6jChy@-?xo|ZDUVl03ur|k%h8wtY>T|X>g
zY0r|1=lT_=>{G@$RehOb5C1I{w!QBDbBFg5kSTnaoE>HxFz&uM&@1NZ#X^K!zQP!(
zVlxgJZqHJ9^-}dI0q^+bK76M`&_mB%5OvPoPEpb5vJ>mbK^Z<4C!@Jkb7K>7Hy*T6
zDhYSRv6FO=;GpdTJ+PzD-5R;oM4H}nZ?uN~o&h9f;JV77UeI;h`tMy(o^v<@XTiM3
zO>VHW9acI<N62$ZEYZZeeqQ3^{7ftgh$Z$|=Ixk9=jhRB2Os=dqow(CsQH}T;+{j~
z-ji#6gA;t}X(lhNre5US|A?Ndb<h!#&&iY{#*jiqbP?(Bc5n@=Y6fqW0W~!jr4Y{5
zdr5)vU}-5Md^rU7lz?-Toeaj%&;aF#Gii`&km=#7h`_9HI}m`BNbm%5N~5C{r3PzV
z3ezkwgrcLSrV>T1&Ke3T>ZmzngFkW$YDF;xAxo}<Hi@0FyXmQ(K@)gvKd^ainAJc#
z>s*~RC+|>hv5lnbXh&zgbVjwiZqO@Y@co+S8*+Cz$%^eEn?v&Ngc?c5MR=NS=AG-u
zBZR$Rxcw1AL`Qzx?5e9iY5tF%I$>yupe{aGg0;V36q=jB?#(CfWAY-B*Cw-fqRCl{
zQr-I_i0&WZ=b=xR;B`mE(JPFk9zO~GkJq-+6aPzeSHh47ujFW=P(#Z)-|VH(QUH-#
zD;q>HNEQAw3nFzjGhc+c>@g+_RVcpHswP088UEz*JQhDa$6PCV0uZ_<eb2c7VXqPH
z7;!(Ju!eW1>IAnM$`cmCPl#k0FrDN8Fs-=lRyoU8=qH}eY*FSi`_Q0eYz~Y0*`IMV
zhjms!78Zex#%=3_g)<JV2}E?$tkkH0ZClE6ID6U;iv*z~46g~DzZG(k|3-#jU8y&S
z{ksR`SyyX%bmT{*&zZHu4K_D0ym<;U+79}BBEZP9+;1iehk<Yj3+t7SWp3f3;a1HF
zltH8Fa|}8RO*XRa%K&+TlH@#651AYk@$}N<#U>q^(y3)Zk?BL%^zZrGZQp25*yZNe
z<<B7Oa2t9;dCadfYjE3I-vc7~lPP57iEd3uzeHwaNy64E61Y7rIT$UYQ79*BnNQOc
zmCbfoHHWrVaQ3viu*sCM*Nr$CNT!h=ZXxAnkQ&>lxZ^c+eQl?r<<78T*o|x`&k#;+
z0Xm&;A_auAo7*`mXJ86UsitdbfE_vo0ex{Wj54Sjg}bQvTMi|({=t!e%L($J^pApa
z!3`$_ZESl}L2Fnt28)Tq@-=7gPJ_C^6{)rMOcD<1_?la%>uoA@(?fJvakZncg`w^X
z{3CjtGZJRA+o8lFL7vQWFIM%NVo>B342`}}@jf@+6FILDcz0Cwl#x;^AZT2fe-@Ps
zYeMd6$bbg|*3A>4Z0+c_XnSqYcQ~j@tXN3fye6l_0_wSo*?fp_RCa<)z{jyYGO~rA
z25=#wft=79F%3v@UW`1oc+~_n`9<XhTiyG4248)pI5|GzH|`_TPlZtGv2k|vedyVL
zuM_#`$gSy=?avOhv+M5pxKDv~lWn4z@A(}WBD|FYv)#{l9BZ#E*w!xY#nr_k*|!p2
z*q&4Vr=m=DYQ&gcFSpV8@!bwz+Yii-vcX(dL|31EHUetT=rMB}Im8VZmhJ;!{0{EA
zz!4dy&z_s(ed=LoIn$%YL8D-;OGYL>$cH{*X><+OY0Cmb<InjaxStsbV8`E==@tD-
zPIJctK6r%L9Ru7)oRY6|R+bLkL{4>x3C$FQpN-gCD<4?QF|WWVTbTiV(~4j5JUi3m
zk5W$MYSSvjRJ<EE2!L~><nucN3>qo;J5uW*`LP69CaLnb3IKF&=1~ZYVI)pBOFCQ@
zjR%i9gh!XB9%1g@k<K#CF14?;iZ%k%$j$6xjMtDMzpi4BBp|%UNaPn}&b(?GLw#c(
zpy;n^hkyjbOSF4D?=~0hC@aa(ZDGVCZA%;9Sv13wgZTeb^M|i_(Bqiy9Tkgw8)2K~
zotfjkXt!T4wjp)LWY`c-jq=`T*?{rm3{KueWx?nqZ5yMM+<zLIz-X$@AIhKsiY_xy
zlJRNcj!ynyBvsDR+&9R-7msy4ts&V<F<VzQOHmvy=(M2}3n|s^pB4Cd(a{@#jvDEd
zo3k1Tsbc8Va`-_IDC+gn$v9AT1CrftIm$7ia1uiE5r$+Z8e*qmkjBGq2(U7dN-|L%
zITyR8WLfKCz^`l3?I4lX^|sZ=8kWOXo`dM~SL-YV?0d}qsVBe^f$FA?ffn`Q?D%as
znqo0!z-P`vYoNgu&?8l$@y7C=a-;lPFf3F6L(JawHd@V=Q|`4vAYoHESudkx7kVx7
zzMDVZ7f{z#6%rLAj9~pxlI`(BIUM0T_w*)STEOcIJ`dX$W7xL@Hg1>=p`-Vs0%<9Q
z6#$9D>(Ykc;u)q2=Tio)-Ah^Zoj)^NH{~@lRIA1c&#o1-;~l3;?)EDfkLXb8IHf~*
zBi}<SrfTx19hCXryjQzgUtTRwE}oWmCFXHe>Uj<jy-)`46Xb(9NC|!mU%z`zPPuqM
zw=Y4VPY}^9!S}XHo6u5Oi{XsKO6EQT92MGxjfw1X-(NX|e;yprtq6Y_j*1(<v&~Sr
z@zE*<^hU~>FjVIaE;o$#ez&gMX*_3wGr5sC*o70Gkh>n6o=^_P_-xd_(vefMX*4E%
zyb@1{`cE23$*JbY(ro<M85-4*<K?vsxmjCo)C!k-WpW1TLdzz$<7UC6maAa10Idu!
zf^}mikFH9&2C`VTfgx}b11X3d2zQ_~z4$%R3mIyj_%(;f>olaZdlZjX^BO(Dqb5u{
zc@zq%ux};Q-2YoSIC0T~?v*K4SGSPhll&QANZWrJ3|%~VKsKGK$w{#WZp!C&vSr`$
z06wV=r9ALwBINalHV$!KUyA<3ZwDjh;|H?o7e@i-H*@L9!u!9#;SqnsEA-to<hMdY
zIe-Z_7Vb~!ollZucH=bn=;!~R*%x%eZ0-^R>?;oKkmQrsgY;i<>*@aW1?}>Dq-7lr
z0m_X-<_G$_9Pm%hS3c7oQ=z+p+Ei2h@M87zRueI-U3ciAizQhG!(aJd$4w=ZN+ha~
zQ0OazolL2Zi?B`<DX>~ST6LV|CDG#xwVX$V_Pe`MYk`a-<A9A-f5+bHVNZYv5j8pO
zc*TFurxG*!37XzuNomS=1)aLP^hV(PneXyDo|t^&VrGWEzVSXF(vj`t;hJemZg+3s
zD?B)f#wU`BP5A6|lU=3@_3mB7XD;<TeR`_%knN`h_3FjC-vJf3D6Gy-9)<2c4Yo-j
zlS%2j5_~ai{{AP!J^5$XUCb@L8RGd{bSEQj;?_45$oqHzcMdUZNc9ESdY9)@OH1vg
z5L${!uQ()ePJ3*9q>eB`Azr%F+UC6fX^g)Ei+P{<%F{lK$<R%)IgbnV&L7x#=#4#S
z+$j&2H>><B@@)HEcH098V?blE*y0E9HYGu-R^MnRjgu#)4gm+Nb`MJMKoqb&nhxP}
z_dMB!_$)wpH+#7sOEW(oD2={iC0m<+6U_X{s++_`$Nw&v_&|61mu`5Z3ztYO*pKYX
zXpSB9Y)mM(OYT}~?H~#U5SN`5$#fMd`Y<PUo}X`zQpGaGGz=kwWL8$0ck8`5E}uOO
z@B3xSp5>Rb6+h>x8?&1H$U~Ix=KU=b{N&TBbJYlpA2cKqgH&M`Ty1y?!n}f-5DL_i
z^Bi|nd6E1PnveRkax#;q{9@<6NP(yR6Trwjk!*`8hDA}=n@oz=wqIhVFt9tf9r1yX
zJ$3R?S~#1Ru}eI+3pt)}MRr4jQS_OI(D^e!4L+4X6vg0;n0B{T#Si6(y<+}#Yn<ig
zy9wNk{N@LIwfkjo0}a=47#>IwdS%2?t9BBUZwirrfxTY&D3|WwL^o8FFA4CChQvhR
zAhgMW5)+-)vykBhfH@+%SMhbaQO5PgqOPYQ_~(B-dFhS)A%5eFAX4LhPG0}i<$o1E
z@v$H2rH{N&4E`wc#&WUX<~C;<S4#fVDMKo(M2zT2Nu#NdU;z~+kk;i&Xnr8_Xh|b!
zObXdyeimYelW-JLP;}JK##78>e^8w)#v_tOI?=~phvnob7lp#Yq{0owrDRRBL^j4t
z?}?O=ttGdNZYGp(xQXSmdM2wWxA}D8&ZdbPkEkA5VaNxhwHT@d@>>ouqh;N)A=m8n
zr<#pw$MOJjlfn=O=7U;I-m)02Xie>w0F;@1F&@Fgys+(tD~F*6#inXx?2qhNeYar=
z1Smk2cx<uc8J6@<{$x!WTX30x)7LtJu7z;+Ok;qD{|OJX9-Nxrz(`3#_t+0^w$r$g
z^_C>wkN2y6*BNwx-1A;k)WWjNyJ}W?>H_)*>PwNA@E*zDw#^xwty+eAwI>CcHOo_u
z3pI*<VQSDNFra#*;))DHGoYQ&#LC`*UkcuC*Ff(f+e%(S1wJPGmbum#r=E>qDVT}U
zz4@+wqSnaeWI@2>V0;1u6Gr&1H^59$hp9gLp6$QaMA_l#ugSWZf~6dBr!sb1OIv?g
zx49NrhBn>=tPXBOI<zajE52ZlHhzl?qlilHhSluys@2<gm0Tc=DzAz8=b|G7iOqw&
z>SWl|N9amg#6^R0^)WB{<sB&jCF;nAtQ%Ld{oMFUeWWJbaa5apckr5m7LsG_{tG-l
zpMFL^y^6QDrXOLZYA-J`Z4r*jm68uhTfQk+$ouDkl_d~6rjS1>>{h{rbD?BoejR|G
z-I&pRxOA1X(g}t5A(ZA}MI59ZvVEqPcx+690?6i)1y5|?SB6CXDuiqa!}wQ025(Wo
z*9C0kmN~uaXfoExs`$V00asH^$0Y;Up}qAXzx_ti9xP8a$+|OS7~FIBv$GTYM&10x
zdtF|S^gMme+;5^cD{`03fZS;k(x~cZ*9xfR+bH9M!$>SW%bc$Q78dPet-`CWF|3|H
z5rFj;eVlsVk45K9R4l^+d#|**Xfz(b|NM1lEj>syBjdyDN%r^2%Xe0jWvuA`Ipbv3
z!_byHkdYuKh@yaB^IyTSW_O<kpOm-C#CFOK))!o2*Qr=Zg}jE8c?*~7C<H#bHc)8&
z6>yWKGk^GO#X`9_^KLzdtuW2r&IVH1QQ2<$66`2lZ{C3uv7>y)NY99XsQ)){b^B+Z
zESw>M!F7T4ckNbbxgq~sx$H{-BLv3pxskQur?qb-3#NKTs?(-^WVfKl2DECaw%Cty
ziNptG<M<_b!H~%YQjE_N>6leJ#>GY%+gjfS)>!E2*%DIcAn{Lgk6%3qoR13w@5#S$
zXMHhUkEMxEDzI)9aX}7oX@l}5>aDJujyKmqEQ6S1e_ImA#${Pd&Qey=-P9xv#_>XL
zhelshzNGjiow-kzKYHJx22cs2^K~0(szrXbj8Uhc2^&A)GBlq(ThMYFKPMTfFuB03
zxwKo<WTBqGNj?&YDIR6vW=PU&8A`J%VoSWB#NuvUV}zM+1>@$I-zO?<A(rSOMq>&H
zM7S>B@jt|dyiSz*_o;<hN)T`)%GZmlSUe!Gu7@}kHiAtn2T$L~0xCsP9N~U<ivh<W
z7bv~`vms+jU4uBin6hOhnQbe+#bh^FlZH)gh?cof0-PqT=3j!xQ)ldEX~rc55FB3J
z8H+gXY_|83)@}RP-Gt{XH~xQXXXfs|8qZFp1T~znCXaG6)@+C=@wv?Oz3-+n;|VEK
zPUa?_e=?h!iSdvH?T#wZsn@c%U-C#@=8<-iH6=L{z8+rFGGr6JsV-5nsCi*4X-v8d
z02nI<LaC)`oIn2%_SPd?zCk1g9eF#PtQzysRUhu8pvk<JN{i{u**X~;pgcaqUv9p*
zk6<xng=gu-rd&{(2K=V<dI0x~i(Yzfw!Yaqyt-Vv%VPMO*}$z6ciqt*sq0Pfb@Uou
zkLUg~RsF1Af!+?6u5@Zt=Y6&+Y);Z`=Di}m;l3MEjlWPMq0+|gjnhcJf4DNTjP#o7
zfslYb)@8Ik*DxB`Q~sm=6r6J~-JI5FQZu(b-Yk<rK=fDJ63&2W3CRd~EjcvNo;noZ
zI8fT*8k7UJYX(6TrAU6F2K&Pmks>T(%)7u_?IuK83*46L-&p_FCC<C$gX{VxvHQY1
zm^Y2B;*`GOYbpq?w1+A5QBIP&Z{QLwcS=nTdIn-@YPhasjp5gk#Zp*jWM~?S_JZC}
z9Ta?3ku$8q1)p7&8j91tLWKB&o^ZeDtdp_G(!y#sdY-o7tt&&SAUGRGCwXmeWBUh+
zk&Qs8bqt<4fcKu)Mia_w1zNcC@dxh{O|KD~D@&ls?fQ$SmabkuIe!P%4OcmRbrMir
zmJIlvpsFfT7)I1+y5nsJYl?>=J0WI=Y0px#h;6u<B|H%Dl}498zn|=jOQQ3_>EQ+D
z*;~!AAx@<u%Hd4}W_%~jGaG=8op=f1oWC(vj5jz4l-|4-V&FhkT1hUJou`0`#u#^T
zMR3O@R2yE3eJ_9%9mtA5^s7*hV;ufHL#pIz0@2wpO;3s9a^wOSxlH#odNCe<oCO0H
z&WVqT4lvY(oLc=-!^@`a{Gr~8nr-Y*gM^NOU!OV=;Nv(Qtrdp)Bszzsh&ncE-Bro$
z_Mol(9<3cO70SZeVunL@!NN;hO)&)qR$HUAr+2dNA_EN^Bnzl*aYL@N%I=Y?_pU0;
zN27@6<|fuA=lJyG^2BtDY*t8LTC{RjU(zqjVEe!28~(n0H3GCvoOaNz&25szch`0~
zLe0u3pQ9&#mU(w1hP!Fit@X|esv0pxx2jf4h)aJKP9GOty>p@JM(wSBk4IB(6sc!I
zif$|mIYA|HGjCs0RG{9wDO$A!FdctQbVzfOt(!U)<Xta-F>Da<!}tZ@&95w!Bc4i@
zc}{pO$x1#xhk-f@N+=YsLk`CL`0tHra5FdDY8)pWr<qPpNJ>uNl}^Y|6ehX)r0a<@
z8W7lSL-pjU%Z#AEHnL1GjGu@`b~KqKP5Y@|aYa(e!t<(NO~+)jsmQjn*ef%g3_RlQ
z^H}XE6|3LjtKs<V>X%+X&O5Bko1Epc*micb;S%!)0Ly;Psp!#7qy$+k2T9JOo={t8
zt}W$C(Xp{8XVD(FXli8wqJjzyTs2s2h3&BGLeb%6-p>KfYN=1EBYhz&h7p{1S`1uo
z6PGaF2`KTRV(Ot`nbqe}E2;|a<WWN@Lxn4Hhb2F?&9@QYQ5$!e-RRV4WTFVoN-|)6
zIQ8(;fw2fxuy$UOPUK3GiQ`M;+ry2=ZP+Y|;gz^n>`kXVXJyzSH8l-4xmh2TXFeaO
zT}qsNIcm3w<Fpa7=-VV9ihjM5!)ghO<f3Oy4)$X~e9FD(?U=pB?BLR+$!;%eglQJ9
zMGV2%n8WA+O%^c>z%WE15@>*CtOHL9Xc|)#VgYU7|4h_kW*E&O>+ajkAY|cOTyt+E
zD+LoUn9Ue@0;ftgnVBdBFphlR0S^&W??wfFz4mbe&gT3gV*I{4Zi#@P18D=a1KG!X
zo+0#B0C3w%4`3MVwbouY)2j`z^=?g`Nvq)c!m3q`LU~>sBjEH1c4-5czp4VuH7T+c
zmd(eIDo?oKOL`ee$}qIK;j9b2>a0L<-vl8nXrpjduiS^emuxR3z&L2X7O>lU;aCC?
zA~OWPz8Ulp0!MGOEg`=)ty|guD6Ct9?n!uUmCKs2pI>Lz=vq-&Et%$jc59gQ%y10Z
zd80l*5S~Whnk!2mQ!va1EJ#vRm*5kU0aNOf7e&f<Y7h;pfy#|F+kS1VM;GDB_vh*-
z3<Sy<G^ycUOL9~HTwz9HLQBF4^`B+9Ib_ktF|QV^p)AL66Fd98&^&}aLggOKG!bJ~
zWWJANTZ8GRe}4$Kt7=oP+RaN)7?)ND=O)*iMB@352Zt$&mKR?oX;ro29$zAV!b>dE
zL{TelFf(o!1dMzFss0o{2(Vd`?tIV@ud7EChm5xv_~XL>B-$m&$>Qeq8;2mgs3z^&
zT4K@NEAE8Zek|fWjJMWaLIeq*k=h>ex%nE-t5c*6E!3uF4-D8PXg>jT@Lq3B-ED9n
z!eez?3m`niGnr>#Czk;dRuVF>A^EIsm5o|2o|YgF)o7f*d|o4r&~CAN?4(16paWIm
zUFlgGA7&bH`0q!68+m&k=pq<-Z6kkS9(xJdA@mExAw^-P<<4&VrYHvFkMg7$eyX%+
zBC<GmEVV?i>wru-gkvUcZJ{VYN5-9mfx*TNqyQsH)d?*iaiX!*W4kKiJ<2_~+PC~+
zW1@-NK@4HHS4lj=j<Uz?z`cFy99`8mF!zohinm^d2ONjJdmNAJ-e?YVRH^3=vWaKv
z6Txkmr5SAdD+>4Klr=(x$B?%KdN#P<f4t!-=EDJ#!`0|x1TuLol`Q(~7E^3<=9Zz?
z*EbUFSGUGwrIov)oVZDV{1`AYa*@LAvk!G`4Vb}TTGt{^iqOq+$)pv9mQ!9~XSA5=
zbyCxipIft`7-(ob>;T?a%Z%()M$Y3+T#e^#8K`RTIMZV6CbdK-iEjyvC1W9^NTnSh
zTB$>gMbdjfzqWD}nAKN#hGDd?0OW;$^!rVgk>VbyG_m>w3)Rhk(1cr5u8Pr+^P}A_
zVXsJUgts~y$J4JtQs7&W^(cQN`3k06_+hNjE1Vx@^2vYBg)2Dz?`mixUPtukD7zVM
z9_yzz;{2IGx|D7ZXu=yL)&%YfE3fDu%W;Hi2bpaqM|0t+xb}HOveR=d0r8!;$<YuX
zgxJMGO7jdh;Nhlx0n3D(Ob+E6A6y7%UefrpYf7Z_zw;!DqK#TZtPMR3;SLfhLo$~n
znQfJCXc*ho)vLNI-c73PT8qxbJE0M$8q`t@Po+izUQ!65sH&6($T>+xA8&1RA9`VJ
z_59i8l>qI+qwYDt-#>;`B~%Q!gHrLvvdAgRO<eI^7AWQIbOaOh2#8zA;eijZ#8%Av
zs{}F2hb(qSLJP8&zsMt2k*x|>wj_teVLj1}9WmT}$nYpN?7O0?*~4QM(x|hWW){-#
z#!ZPw;lcgTao~&w&nG&~B876=BPp#z&jSg;hBeV68OFNE>)eT>WvnEmx`|;R@OVYW
zhiSY=)!;^>B>Dc;NYq5?9a%*8oD56%VpAl8E@OP1BD>Yexlwm}j63i|?t4+S{otvV
zU__opEg`>dQH`nC*niNf2HcHCK^aPf8Hx!baPvE*e*%kIfe%@{x~{QBbtrL@aa*!#
z)*Ej+WfxZu?F3he9mH#KrSi*-^u2L!K5+K0-O<oOMq%H#=$-bUaI)~XOk;fiq$o8+
zAl~-Ddl36BmZ|6LNNk(uq`{anW2>eKhab*!?>eMR5_p9ZYui#p&Y(D%(^!7bVurg7
zo~)>ejyBR<88tftL$gAqeMM$Fn>=prpqW#Wc<JyAf%0%;^TpCz0_jLu1a4G<uS1OB
z8*W#)rZ4t3mKm5LtTRMVLN@QAY42C<bvq?Y{)t(LbJv2!YBI}&Cg<2F=2r7+?{}VR
z?OvG67NJNqD&&V|3e$hMpr`_lMw?3}vjg2JMHo>Q7}pHjWo0uWqd`sM_pCLWI0w)7
zw%tyf_G!jrsX+A?A~1$AdkYA+7aFVJd4)X&6%Ax8*WKeVh5j}oAplvCUyHncch&5z
z<MA!$>nV|9N$oHt=??c*>UpanZEiVn9Tc=NhYgmsxCwUaUOS|`QzqyN%viBE-lgp}
z1*XI0gGF@%s2$iq>u$h^k94JUWq+?cUtFS1DsvF032@z1p^PQqB~!-3G&F1%y~LN|
zX45g+jz*Fjh^S;>!+>rv<Wh+y&ePAX9t<)Uz1HNt3{_?-H5t9W=Eo$6W@FZPrBHzh
zbsUKqz`^&CQe8Z7#3&Pyjv7aI&5h2xp6sc8w-F}d<VB$|4eX&O7JRpg!JQXuCHvgK
z#d3#n2koZnV5MUjo*A8&Tf{8n$Sq__&*c;V+$uVC=4m2vS0gX9R?fI}7J?Jh&J?lL
z!g8EhnQ?sJ(9zunq&EDiG_Pv-9gbsz*^s>qIPBY_m+T+JKoGPURG(vn+>T=pv&POu
z|2<54*yD<<NETqu3epJ~0UJ$6ICY0wTOwsR0dhWp)sKZ{gg3c9^K4wP*`<N5Ro5$j
zlr^qJRgo9N8*F|lRT?sTU1aFSw%}U<(RqdXQA!p$#;heyaZ?js2Nt&kFgoK5;!AFn
zDCl(g?MXCcslLIAyoeQkvkiTaMkj+^h}iB?Hm-`oNj5?B@!e31%7+dqf*W%4WE3p<
zNI-6MR~6i$@0U#kOND+(b*e;PRVAIGu6ltY`344TPNK@P39A`~XxRxX24qcn2rdgZ
zki1FD88o8ZU3Hd-Q->;wj7(NFl&HMqa2DD)uEC40LbS#Nv8r$C{I!pw(g-1ZQW5q2
z7Ehob1gpCm6F%}l87H2Vo%XJ`-NEVc4`AW`ndA4I7@3<A=M^8AJ@NhX#TO=RtxMVU
z+~*zS5^?RQPTx>$ayQK4lOuxC6#q?lQpxDyBXUMBuC~8GKba_TbSL5f^ZJcAY}E)n
zuxEM+uJkXfSVvP?1ZBDSzc8i%=;r-fGcNewkvpe<(E*X1<w0aL>rZ@*SIazCO9G21
zvl;SpB=An{xG*>HouMcfs#;<_2WgCM6t8LxHU1uvic?OFDf)J;^Z*=b!S(z#2@v2B
zyjr+1fI^o!*Gkt7)wetK+KoMX+ENhiTe?;@MOr;q(snA#3Uh|ByfBz<mMO1(3RR4Y
z!%nl9q(LmJdDZEl;c`jB&nXb;s1BKXX&HoXIRZko;*u$|0Y3axB<+rNbnRH0@hv{6
zMjnUCHwxvbuc+|_TfntQ8Si1Q!c2YA9&(=sKO-!Q=S(Y@pb>^9%+E-EoT0@c_5w<M
zl=(AD$5!Z4@o3No=l*Xq8%2}q*9Of{GWs%GU)53(46#K=2aAcohbU8JBNdPZY<uoT
z^cBf5=V1}Kf(uwllW_%X7w(2UjHVq;&2bA@;hMv)VGco%Lw$v5wPom(Xwo$n79+oZ
zh5pPBc71oZeMT;x<&L2MTA?}Afy#Ps07J`#7_oLLIlF~61|&fx1Hp}K=%X4e>Bex0
zQ;}ic5RpzEaw$KJ)9wpXJT^c$ej*w`Lj=`>-BiozCC)0W4x7@2#$fQ0!CPjJou8t4
zpma2uyFlk)M*cKF`O;k}0$Se&)}g)+h!hsl1gNKm0LD*P_cVf^c`gtluuFAa1rwlg
zQ*=IfCn5owbg&B!fXwR5EMJq{;V<B2Dk%~a9MPpm@`Nh8fJ1OhiN3Dn7$%q5foO%g
z<u@bVu0_@D)=o94aRTPuh&Hvg#XQ?DGY_urRY)D8OA7h3<RZ&-KEBAOzUk9^-wDSf
zd&a8aag$YiUI54tKx$&B$%l``n#YF0|3Vv&8^J0MZd}%Ga4H!1e#z>=|N6cEnbS<%
zLC0Tnx7Uedp#ACbG!012vkYL#-gfUmb^G8>^-ygmJ7gQ{n_`g^^YVSPnGXnKC6Vr+
zRVxBM<^)2{Sq|Ux3OWy=6fI_VZ3IoK5Tdq;`4szw0?wBoXn+91>{A`w``7JBq@DF`
z%Bvqrv9j+n3ohBzGMchRbxmF%M>xiDXI8*h3!U%ojGgvu?5y9*Vc+rL4<+0MSb#?h
z_O4RPq`XCcaBg;Te0pYH1>W_GuqyzyHt(@WULcNLddM&7w1OLqE=^Bo;<$_^g;u=(
ztURWtsWA}{Xh>{eJ0qpHDoq+~1#}XNR1dAW0t_Ul<6b{h=5lNXf2L(#(UERh{vrUi
z<#K8W89^2B_X*^0w=f|US5#KH9~KHILY~)W^#^G5doyI(PI(|81SKj0DfR0=id_V@
zIbzY`o*?21#-aA-4!+l&mCZ@WNQ*$<AIW4iyDf>`p6(_G3<!sdirxL$7vhP>xAel=
zL38Q&nL@O`=k{cG5nX@qfxdiwspd~!*s0!OdhPC${7AhONeN?WSyT=4b`u3q$!*b)
zHa&3d<QQ}E!qxb7&=W1+^*TuYv^KdBsJNeVS+Fr-90@z{$1j(Na=<#Q<f<HX^h@is
zRu!TPp-kc-kO$<409vyL0ug&AqYPX~80;0Q{zt<n?r91E_#~F!`<?Pdu*7e@MGX25
z+yTq>z;ljXy;^JGIJB9x6(8PF34ojIHaMKHi;al_0fJj56_c#As3K6jyB0$uI0YI-
zBa*hgk<cJf``iyH*h0R>88cqJOcBe(wISlWBSzkSb^7ESh4OR`a38K%0#D_=b_d{2
z&2?qvOkw)VlB#Ic#}3fTnfm5(gZ>1$lr?Ay*^g&8vuM-~nxS$+U@2e#GrUIPPK(O}
zLb#qkB2NZSvZK)prLN$O!eJBwY{GQ`A(i8FRtcAG+Z@x{Nf%o39S>t;tfcQ&B~;r2
z(oEc$SKE3%(1uLi`%kCHSpBsI<yU@x#i0AB8X#{~DTl2vPcV<Sdur4X<~FVB>5K2v
z+ZgBOYdt7?Ip4bh@LQ{*FJ24`J;bcH3YW5cOfI;%?AtDH<Dp{Gm(>ZUCXB{*;EX~M
zm`bMPQU#ZU%YDJ1mE~8;u`Bk%01c52hdE;NJb?URhE!x1Ir($;?8El5>1oCri@ook
znI4~<o#T)P(0zbE-H;g87ZGMP2{h~TeR^(c<!C&iU<sh!{$V~r`344Ej;i2FlN47Y
z4mDE$+EiQhKcLVPq1N`TQ+BERPpyGBQFNTi^cRMjC2{Lx7vn{?Lo9XJdenq4n^BT*
zSz4c<1G|HH*q$d+jSx+duovh3dW+lJ+hlLcpsS_|3~V1v1Gnb)@Qv->EQ3zmN%42H
ztjRxX<YuC<L4M%xQUmaraJ@CTw&vz6k$AMV<h3q|oD=L>VH+rc)RhlmL4qY?XC+s6
z+M+zTW`$W*8zb(f2DK)mni6=CYqueWZi(x0NL8c?kVKSf(&e38G<jYn%HyyF@Hl)h
zXj@V06uru_!E=JbbC0`9?K6#KZ_W^;!6;Gpug2QB?#u2H<2r;OD`4O{2@wLo!m9!;
z?9gN%xcOzrn2ej`Zg!zX0|uFmjXA+L<bW?zB6<1W<sPEik9X&bc)A!uOme(I6sX)_
ziMqeaA;4<zaSpBs_PI^vx_)DM%`1W*QwS~=RXLWdx1}5^p8`CtB+H`VKb3Mg<#X37
z&w^344~|fry)BWJr7^kUNG%@lx`KKny}+G#&AxJnH+Q$X%sF!Ch{+U1>*!_pMkUPI
z^+woS=px337DaZj#zh?>l$0WlGVconp9EK$5B62!ux&@y8*7j7U!*!q%k@fNaDv5%
zN`t&8LogLGFGP*Wv<wO8kW&zk6N~=>i9H~7Tb691y+4ZVL2e6PF(8-iA*6ip^0vEO
z8?nSjgt|XC=9(a}@G-~@p5-dg-V(Er+WieWhG2Tr*h;&JVUYZ}DbTj3Yk<?4<%IqT
ze%pQAmj#UxM+>@c!;@-`2qw$|--+v3#)usb*Okxo0|*7&-ke?uG0-gV?d4J(Dhq`P
zO)>{8!$1o-uo>)bg~V7Y<dRbf1;YV|o1kKZJRuhX$LD)(LQ6ZmI8BK~b0&r|9;^A=
zp6^lM&|PE*+Pk&&vs~rxr8RL-b*N^ouCb%l5Q*z&DU}{;XMHN+?n*!??IV+Q^^T6<
z*{i76DMTAUBf2hAMTcQQ9#XcV?smp{rYe`q0Ubwe$=+)#I{(Z^1T~6Kk4_9AnCn+8
z-xY6|HbAi~%~v+Na)?2S%fFn)B{n7cVDsG9sjGSThHRE6aT8C*7EFQmS0_f{4=5+S
z$&sN+bL;w{9fx<GMNOGkW4O38R64Lrhr{bq^q|$@&(HNUnwLqn3yZqRVlT<QS}r|J
zzRjOz-&V{nJ`$MwSuL`tNGa=ZI;Kt42Cr(&t#B+(%P2FC#aHMA;}H75*Q<n5;oNyg
z6i&v8)xOe?PG8D@g|&V|Sar@#-G(XxH9oRJ@=6ot>SU*K_|W8F<xi90+DC-2hHVw|
z0jgsi0d&Ng|2mxe58f}j3c7IJDLMG73<NDBNYZ!t4=+U4OH!{(x==<kGDnD(u0rPu
z_zuI(8zY+lQ$Vc0>_<jJ>R2ezF2hO{nk@?w&%#+Y->&P;{9bO`XI6Vk>>Fo4aYJYl
zWW=Dw*Q=q^7?SvAZXk!-Hk<bd7?VF2!1F05HnU;S1fuOpAz@-C3OO*5G1`>uuSe$$
zg-51@2H>Ow@r<qKaf67OOvDJWT0rhOYpT0)zVWH|X3oNO-q^qZy&}hYYI=2|$HYDM
z6+iM?va3~*Pr}E3$K1#MrRt`<l|S+b9}#ea-A2ffBrEzGOTRxEAVLVR$wZDg;e-G>
z89*320S+&k@*q@M0B8q!4WxblX0a**M`BnzPD!}4t#k>ii4*VcXoIE!1La#{FL4lu
zs7_Ov1YvR^X}Syu`-GPZ?oh2_V97m>wAG<NMyBRK;!#tNjx|b_%bozGwn$Ki+DS{u
z4z1GKN4V3~czJlgXMo{CFJdANz(?vYuMzQ9TnAw{pI(f>qd2(5!0rB(2gvYCg}X#&
zs#}*90)%62$;b&(G~+XB0$j-;?{`RS`ubJ>?3dyT!l1Wp4bpL?OVib8`V?}X$YS<t
zvQqt<`Ggd?7z2~6K0CYxk`_W>HbUxL$y>9<6X;}XuC*~|PveDmh4P3bt{^9{chdI0
z29e;(M$Nx4TgAh}xc<7}Eqzz0--)-9;z^sj<}T}Bp{=CB16vy2-N9<an9lB@xp(Ov
zFm9tmF=(RiCY330;${?f>uEuelTvTeg`Ev*hQN*ptPvGA+u>(UmLEZ{V1Yfvpj}eC
zu>E}X5Q3x=*v1~JOn=BbH(8KO6~k-&9Xo32)@YETu&H6|)^WNMtDmd{03Ap4p~eU}
za`%>zp9->`ZCZN76ByhwV6k(Ie5f|9nU+eGyyIp8QI-$}$T7MYJTU7tmaDp6XN?J4
zi;!BSm|-NP>e7D%)F4KK)F_$~7WxK432Nn9=0WaK1qI1U*2RXmb3z}p5D$x05sE#f
zVn(OswU(DNjF|~2V=E;wD(fWP%V4L^(kwX_EEQm|VSim0W#<?3lvvAvE#62WE9ArX
zXJ1Fsm52dGO-vWcaFG@>x^T}co2?;(`VzcVr$4gag%Ukp4-=BAl9<Tm{2t-v8SRiV
zZFt-DKM8?F!&Lp^C;i5;&Wjcjr7VzuEJ)|cl(y3wyNB?3q$tKQyMKF6I`1w4T?$@t
zT;T|I9ssflkL;g4`glJjqTsx8DB>(fEi$utjU;7cDO!;u4{Uv$b_p8uU@0v0d)T2_
z7~;1ZDVrLKqr&>D3L7bdeA_Bk{J58ILcegJGQwNq;q>xeHJc!>d+h{X<e<ua<f}6v
zwXmN3<Tdw^<>RIMaOVHuTuYyypY4Cv>BqI|wvD`S=hd^HM?9Ca^-*=S&-9YQ6Hut~
zo;qhrn#7Yn5&ANk=LAh|oFmqZ)}o4&i2v53JJ@4vmBqU!#J0iQe)a=Su(#XP5&2L{
z_d)t!)bxBYQg#BoRB~kQ>b1zzW51I<aWV1gc9X{BmEQ#G4)<dz<+%{llO`G^2_0mN
zA^=X5>gg?}2w}SYK;)ydm%e&waQ$O>O!_OKs5fsjsvp|N!aKx@pfpOFNzcjxm0=vd
zXz1Sq>d$6c1IMQ(IPTIbg`C#k2C-q<rs<CCa@u}7)@i#PYmVK|n1M!V?DM?zo5)S$
zck4a07Iv)D)<f;w`0#E|ykS}pX!%Y4!8xU@oO9e1uq^CrU^*`&NVeXvD`&=DLYOOz
zZ2K2hl#;K4x3r=OIP{@5y^pHsqLmxLwb#6xmm*OpdL6}7ycphyCepv3CCI$HDXMQ~
zC6(FrQdziuts*imx8pbJb|p;iud&OZfF9Wf5ZQie+Ks*f*YpdC!_Mn0C&$4OFwv0H
zC~9+nk-H&OBj~lxF~0-Yd)PE;Z8nPh)L9)!|BJV4f1o!WMNI_o&3iTmZp12vnGNOj
zS$c3R?|jW(J~^)f*93k|b1FU3ib2*`yWv(RqZ1H;Sy!8wVzjT*vO2PUFRgSAFh^)t
zin*mZTJ>U%fs%2&KE&T~Q`3KVGlqnPPIaHUimADxIfWTwRj9rY!}(lV;bq?i@p(+q
zI^s@=r+KpL_$}8dGa;eV9-L?TM<Nkfpb8@hxEf5Pbk-Ni7`XW%$#Lsyv{YVNc#!!`
zjX*qetiZ4CQl@`I)kNii>OEHTnW{=nmo6eHHKFC|7NNH*w(r{R9F*oE#HTx8x!kZ*
zRb=4M3ciq9G4$sXsKC+ZYH8bJzO04Wp&n6J$Hm2)PW`xk785e(U`WZV?MxE{IKne;
z)A<@a)D;Ib7i7KDtO0a24UsTCKw`AWQNT9b4yhgx4TdSK^#5MD0dG5(os>n~(R+Nq
z--R$ul{>{{xhsQw^XQaK<v%gGHLTxl$c8}SEFB%)-@}w-5n%A4JVJxNPRunqMlp-d
z4cooIm1$f|Gk{3p*{Q|A7!RsKI6nYvXI|3!YD3WivQ-B~%}bGvVap{3LwRRg+pey`
zB_UNLqt1}ROuH1^VO0PI6ByO$me=rg9SPFN(Nsa1kRVnRf);0nnkB1YCfCoE@)RYE
zAT-})Qbs0UU!tk=HO0K+36E(SyhR!dFi7XZDw0K0l3vI>X*T6HLnyH+E!F_m6Pm1@
z8H0=(<s`XA^H&cw!z>KuMVyTr{E`#-NwkPoPEd+&JLh*Tcrmi?FEmuE0_(h%ygM9I
zugHKG@00!&v*_MPkFdqUg62T!2~>N@v$R74)wqHVsvli`+;M4-LH?^+7x5Hk$w3~E
zAqdJYrI`uLFKAnAJ;B)bXhxpeydYwyAeJf|*A6p*1bRJ`R;ET-mAypf!A0HgHzczS
z@H~(NZ_}!?>p-O-x-8NtVU#D<7oSGKLN=9qQS}K*)@|Va{G-;R8w@gzmTAzJkJ2iW
z%vjyv3T3z452-1{!r{%M!Zcrf_SwU616=W!IZRqkj_1rEB`0`#11d<wT7;Wzj8QAT
zw*#Tw#5#8@$MpYBz&sPgt)<d+l7_Bih{h7&AJ(89!)FsObLvA}*W3znNrQCm$=EKs
zsPLdCSn=%o#<|iK-JqKiTtt^OTIX9VmCqyt4~PvzUBQ<W++ypBCerAW<0(knt3cCR
zR}8@uU-{G~$5NjN)ycJbD?18P*J!g!P&Rvve<j>=+%5oWVYa7iMnf~el1VhR_Yq_t
z2#ei|o!wY^`8z?M_{hgA`Sr~#$daMLe$#7;d}PT0l@YJsmpqMw1>~>&x$8?q`GR@Z
zZM-oWkW@+1(7_l{(g3<FV2V2duCOv1$a$!5hanVrU;(9H8spff*BPY(O>edn(YwuQ
z%jaz3V~DsGzBa`Yb>*ZiIvGWtpXz$8ML_rshQdfcdpV~mESkiYrUX&QxTYxSrlHk#
zMyHV}&-R63(#Jw+`toE;{vZ@P562?kT|}Qaz3a-p!F?tPoZeyjk@5$DqTBv?QKQb@
z>$#D4R!}h7enrfj_mtI-2v%TbSz;~8^#3t~TA}EMBbatp<4|Q$>N1jysFO)4F-tmb
zLo)(wW-|Ds+P2?kA>e;GzENG`@N40C5K6~S=_*V0KIq8-R!I0XUclU0%i?<TN(8(O
z>Z;Vw6_L(#MKK@qH6sSxP~+ITPBiSE%|<m~3Q%$ZirjJkWw`Tuvp_Z^coNipuG6e>
z56k&p@5{G>6myD!B;J>$EvBR;)b-Ft{dTzB;>xn$(NB#i5WpvpsIN+ISvD)FfS%#U
zE={N^5)DZ9ywGInGx<tbtT#FnS*?`<UH1H<m6ciF-_W(27GHJU^u5Ke7*bs%1C%DN
z3^>?*x8abzR8iw0m+jF3PaD06&Z-x|_WS}K7d}0h{3{kZTs1|<5FVt0Tnfs|6HG8v
zaECW+oOdcn;_q9G5?2%KTB^GRyK9a<lMafmjfW445=O}X6<m7?oo$b*{ir8XBGtpT
zqh6DR=wO0v$0%tn<{cibiZ!-`H1Wn|$a9olA=fn$G#Bz5yhY9*&qR}1w3pf`Haf|o
z;_f6JA^mq>^G4MVkWWze+i~USRA;5)_<6Q$y{P=ZKw>%Bp0D4COO+Z0P83biKnYr!
zHq$~Ywe(#n(mwpZej2m`Lq12iNtK3QARL{5aMV6|f;JVg`m5<;2?TZW(%phmv{0|+
z$nE2ZX|M$1!ax?2`@-~j_G!D6cpSZDzr$Rr81s7gAPQGVG@k{XicvW&XaWgK_)^=}
zd<SJ*Wo2_K9|`e&J4GO9oF<R8bdj+#B3i4$<nG5Vu|sd+oxIy0DGail1?fSJMMJ4K
ztSa2rl9T3QjOrtNZ+^ej9urM?W#2t$u(IvFPmnL#H5y@rY-CRTfM`U1(^6hhb07*9
z2x5e|J}<(?3WkkL^Hi0(mja0Z9_s5!p|@|BK?mdu$$?Fp`(BP_8{ig_qu$sKF7QEG
z2NP0BB8QZTy(uPaEPu6wl1@LpiKwM6%+QmU?yF4H5l0*kJc`hXbzJ7N(ivMaXtz(>
zWonf?zh)*wS==9(MOvCHKqWXsCARJ{bOytKL?-4H>Immu4^<I_-6GE6)hW!h$uSVI
z&YTtB1k+7joqcZ8Ns6%7x#}}th)+KR^>ja)s@ilvc~0|E#0@o5C(_|c;E8BBY=RmJ
z)jz_7kJFX-mWJ7YIN{TE0(JpIL<6a02ZQTKhb1a{xSIS}8$wc4>C+w>p3ES|UylfN
z=?8=G+ROgH5}Ti<$KJQ=HrhOUSSb`5a@qDY*V^?Kh#!%1hL=nRm%@ZZ+58|c_rJmr
zCi%6F)Fhwd-w>6zWkuhbu4lecFy<m>vFyM-n>A$bn;WxWf?$4T@3~3un>FlI1T%6-
zpEirwsZ08;6;zSBU5c|E2ev}c{rvqqQd;)a5(#S-4BepH`xZThp2Q5aA^of>kO|PI
zIp7(DtRXY!j^!h;vPa|fO*u;02T?~TwJD`B&ujOv29&ye$QHxCHAV!@11h@@HUZVa
zdy3jtlJSjrJ!b58HCV?H+7Q_@)V)eei;SXGyrzIq8m4NQ>f?k<da8*gN7!D&_5O@x
z!0b!6e4bDO4w1HxXxC$tl*>86ypqat{JYIWOF5T*0r$g}w+3LeZ5Q6%E&2P@oga{Z
z5>~!C-@zdrK1<v_fFZcvQpS|3S))&HQs=#n$&pT@gY}@GOgyQ4hxQZf5@~}$u~A*A
zc5GC9hlsrFFuEPMT-wx)n|hTGcjNX!8j5s6US4TCAe!`N_ib*JJzfh$Q+3_M^Ts8L
zUf*CPAgrsAn&>`JD4Sc(R0;!df0hB0kaUZ8m1TS^Xc9XN?ed*_0~llS9Zk*(EURHg
zHzRyD3;s(~fDJ%&Xmu;2mGB?bz17LhCfs|FP4TG}C?-%zNY{+c*~&N{XK-Vl#_i@*
z(mL!usVT9}_<d|?kvi-IXK_~(v-}i{VRJ@1qMw|WTwCf+GR_#G?XKIa+Oax6?aeWS
z#!D|%^K^Ts7Ud@x9g5?U@!w<{o4D;8<S&+1l7wTM4dRNTmYQ2TD?}UQ2e?S&N-s(~
zXoj7xek}fFJWs1qU!P$vDo3R@2&3V{9Ta9MeH*S7xwU$;C|Fe$qD~sG^y#BYpYg9_
z2|fAstqpllb%l{e4dVMj0L*3FsjD#eVQmONfu#DgRkeIvQRVt>r>0~Carg~;uP)lB
zX+}Wk1c7S@&)mE(sdn+ka>}~ySkHibxNQ#5SXV9^4*1RW1zpHvwjLo_NV?#zRTs<|
z-eGl1s`17yT6Z;j>oO!-#}J5cThMIbY)Mooj<yvfGO{aRNia%np%(+Cx%@a7!>$z^
zou|0<g+S5Q>m1eS)BF^VqYZQ@YcEQ&7DS-_N&--9Wf0)M(#0Uk<N(Ht9Ee-FEUxd9
z9Cx>~rM+XyW-AR7z0J*pJpfN992tWgMzQXrix*9p`NuS-OKA#nmuCgBSmI$`AjIV=
z`29Q3Yd|9fZuUqUOL8hmw7=H)mrFNSE}~(DTP049y1=ElvPqrbWnFn3jOTA)sl=_5
z)P3;>79kr7BP6+*+K66**J?swo(nP_<&s8G{a%fqM()!!hXC`s4$Qia?Z5c~ux%4J
zBh}c2_YOO1=0G9D#uR>;J)8)JPL&)oE|7+X$NdNI3K7k?fr#>6lFIc5?iQ|#R;4$E
zseBPxFIHGQ;=50>zW6MU$_w^hE`lo2rmk{PE$;D{Jgp9=IdX&Cs)-6&rLG(H$U?}A
zf$JB5_wSK|jXD&GUa4o>mi6b#<~#U$D02bdx7@_;j;j@albHp`O#xkKT6Tz7f{JHk
z)rg?xxjYw!wgxG7Bn<AAwE(XpV;^FzmghZO05VQl*H6GJtTzaOsHFa->gI$YbR>OY
z%$RGoGSM`rC9%yZ0Zh`rq>0=OZV|L<i4hXNvrLbfx?%fJ3(driIXPGk(KO1E9s@v`
zF$O_=K=)Pkuuiq)7F7>XGkG+)FL-M2M1bFrsCr-zhSGQOW@W+EXGA6zZDqjkfF@}l
z>(@1Rt#%HetR0t1G-+Hl40dY&n1`y!bFxer=Amxt+8Jx#G}^gdw(^-I%%rb}I)Ri(
z+UqQ=Oh^-yMh7FNz-5wZl-PW9iku9E0GU3K=yAc!Gfy0h*JDqsGHb`gR+{3K9mj*+
zzKje_@pe|7KD!j<5GP96`}9g$u0V8Hk3oZ>!vdLJu~YeOTY^s2tu;P_OEz@A%7XM<
zYsZ5qJ6$przL3w~`I_jT#zMvp$_Hr4RpauEqA(1V&fLy&de#cVEI8I7OwTZp8$u$$
zB530$N-3l-vh9YO+k<QPl_oSMNVAjPQS|_`rhX(AC{L<LQcYwq49Q);D*mSdY&Ch$
zBT{qy+L73suNV<&%h2%SRC3$hOAhbv14-UKRr+HP;9#~S=x(DW=3`#OgRcd9ZLf6R
zKiL6GinrO;$qZQ>kpm47I{Qf@Pwcq;9E0ZY%09jJfGlW;UoC${@ke2MdvIR&g7u*7
z6V#>brZ@~{Ziejy>x7kf**sYy($3i#!V+{(%uKkp5fE)f3BVR~kK5oAW&r&j{GWm2
zBG)a+2+@2xd+9+f2&bfyjK>)Fsb7nTJw<*1dzMf|<5w|#5UB*1+)#%ExrJ(&8RyCt
zHp+|Z_8qkVHj{6yul3(K@t==-{nb<7L8s=?Ee9TNX&VT|y8~-My&Y^XUg-qVty?GO
z3Mco^x9`aZr-q?e2s4Q=VpsgIFyUuCtFNf+Lvv?cE15mO$n!a1L>HA(+^vc%vQ;gm
z!;h0nMiEiYT=wUmJ%=XuCegXGu1?um1c@xyh*{(8XvcD>3K2qw(L5t5sL*&dSA<<F
z&ZLl^8y^-%k2$$f`RzA(Q0^9{<(L}ZIyqK0Sn$~0to{M_YHNrc0zMglRdgmO11TJG
zj9&plqf$cwvl)reIkl@r>l7wTt@mK0Bn|_~bAE%h0*5+*Bn57_p8>CY<r|f*(Kcyr
ztu}3@$Ld7urDGE|Ue4mj7^}1;4Xzi~?0MBv-30{6GIK9WQk(KeKWeH|Qu54vY}!*B
zdv3R7i9{PfDFr{eniR9f938}7SQ@68R#?BA{@v^)G1n2h4qe-+gqgM^m2~?j)-gzI
zodBEhu(}*he3MD+gE+>bB$JILBN+LyX5cYFXzR4aEDR-PyUe(V!{z1b<7;&6Z1-q6
z`tV}#2cK7?|4}vtRv=USLghm@mlmU^AYp<DJNqm?hm$38wdY`Pr|$}7FFgV)r{%%m
z_m~Mu{XT&j<QZXDXj6B{D>uv~^)#E-%ze?Q!6j46O1o5AIj)sU;*g!xsB-yhlT~CC
zyL)f!?3R{J*2!p_Cl_*ypM@c)Wrm3bmWQzUvw2Q|b|)LWz(@aUL8eN>Q8OJix`ue{
ztL@#NB|7ho)$vE&=HaOdn_FLWI-4v~m(#pOh6t%j0QkM7g*ob7qv&6sy@}n`zdC&W
zbsKBJ&z|{&#IN7B@h$OSll<yBb4bO}7D^Mkb2@GK%jCt0h{&YCVEQE$R`?gU&LO_5
zo~q1qHHRAmS&7OuT(3`cYH||!_q4mw*3WqpwvQYzTWfFF$b9p4Ov3n%U`f}~RlENo
zvAKAj88fkkaI*oDX}p#<H953ZhFFf&s9<i`UROqo-Ey;zIsDNs(bh+|Xiye315GM3
zz-EX|KGq^H2)vpt!DgSpqhw#Q+$B##4sjIdLdadM^2a_QVUJ`}F~IUH;N_VMKW&J_
z8*u~aEu_)ds`H0h!emn2*8Ak&9a`A4%)RMi6ChP2B}JBGjPx|-d*Yfme@r1N*(n_a
z1})Jxtn!AZcZ|s@?=hMpJ=FW16t%&&EPEw8n(861uIJ=u0R1ya@0j|L8nTJL_2?9@
z6UlbE+C^d4W^L%2S0?l^?*#O$=&m~kRc{Br8ESh8YapT0XIMP+=p%z0Kg4Qe)=Es}
zlOnC)E7+w4%{UXC#!o+OlDBXVP4+pz*b9~S-ExPR1V5#CgZMNjg&2b30M>zAG=ia7
z|2k4=;w>bV^yDE7x3KyVOsCc(ZdS%ov(YsMaK7a!wm!X&JfDb8eUlju&a@1=V0*5T
zg_8JT?J?^)$tT|GpsF~<55%cPbH}_&G-WPR80S)A**NOR!Bfs{it=zdbVQOSC;S=!
z1qdhvp*5XaI)g{fCKa7Y<^di!Eo6s+hDXyA3At5su;`5<v1ybU8cj_eMcOiE4pG%S
zZAS&(+7vsk#XF3Q<vfaP1SnwCjujo5H2|JaauruTJ&9`Tr%IhUUXO%Lqvqp{Y)6Kw
zgcFsElR_6zTIf=1XoGfsNGvHyHvan7X805qW747GuH@!quttw7_ifx!Fg>f?A|4+#
z>;X3RZDY&@6IHp;RL~lRI;2!I7~DEkFTVs71K2rHm_9I`zoEK?Cea3&b{eKS6)bIB
znO`4pmQF7AI(A*Q$24?<ov7AlRD4FJ2Ko4>X0d*ijrj~YIP|e7w1^eFa>%cWD5oQe
z7bS~3{8-HL)_m~=3?E1jsKrBENoA?BN2yYU4J?NAc-W}wv3uSYWxV~zE=8`RMoIrB
zt;oJ<)LDPvD|{8_r$CrrTQegP(2iQ7|GN?X#I4Y7d@)#xM>Hmv`D@^d4x&P<KWM0m
zV-L*5CYU3i#?_Bpc;={I7Ulys7yvU^07JFC(-Xz&gkU3@cQ<`n7FmS`zi|<e?X%eZ
zLCo0_UFwx-FI+2ymLY&Aago>_(Y%PNM0Zq}x@9+xg3|y9sjGsy2U+2AE`;#oBFCc*
zMu{f5DgL=PqFINxWb28LMR?#tYNMK@-O>6eJ#kO>-mfS%WBp^DMt@-E@)tlGAncI&
zO!@t+w6Hk1e2FexguTRv>hjEEN@67pPsNjKcvhMKlr`E-PL<7I?u4)8%B|#fiGy}{
zKqZe@ofOLzT4EIQuNVjeUp?01UsN$iFArk(9hab;bHpQ0PdMGP<6=Ke)b5D8I$}VN
z<ooW8xVjnceoCv8+v{Ywd;W4}I1H<CG*yROe)LVI7S6Fl4eT}~Tg(uKn{5_%S-kNH
zgzIlWIFSWi9c}O>oN&gc&>aXgHmi0j?#n0YMl=wFoTdTq1aRXFHLoyI6Lo}Js;pbH
zOE!c=2V?+KPk`wsIw4i3+6*BL08^748HWQ5gi9<W_4wjDa+0i`ys{yf$}NBEU}v^^
zCRwO1&1PB2AGgn%Z}U${!5*N=C-kz^VlJE*JJVG<!GG^l$0!yj-<)xcLZ8a1_rVn$
zF!~;cUjAs18=VLZ)qc>>iXh^dkX=B{yCdvXJn>grV%Uv=U{8O3BjF;ZRMh*nW{UxD
zAzOkEvOx=qx|QPgVI)Y#k3WPTXE$>uZE{gL9^DPgRl=MpuwjPRVXHxDmJHFydxv$s
z?!R4C$I*<$T8l@fnNDT>x((jTXI<|SIac5`xA1#?5kP688_i10#nSNwJW$$)@wq@Q
zhrraDnhPmvgrc@(MRgURy28sH>+pFk9W;SUJu)&`tm7Ur_~Pq<*mHTFQ3u}*2z1pD
z9ILYss3Jmbk^V_u3Aw@&IvuGpn)>yV*uUkel!b)MKm}a+@wXbGBpn^6qp5@CgQc+6
z<%y(ch*>B`xZeK4p+m**2Cta=2L=qQjg>0D9x;Ts6p&6rl0|fZkbTw-v0%Q$gdj_;
ze^lMsIg`%PXAUi_TQi%I9FSd}oWe$SmR}5tx?|>J5S0F?UecYM6SN{~5fMTjm6JGC
zUc9*FN=lNDtxrlh>))~%zLWat^tb7^b&eV5|3{(--=(>$gZxkaTl~1nb?)4GW_wzl
z{cTHQPArY=-4mN!D@lhWsdj10nr;jFRDW?OFs%oWeB3lcm~ln|M_g}SNWcUqj7Z0V
z)Wp=OF0a&0>HwdC^y7M1p3%~E3HGIZNRlMb8nZCN6jMa8R{`pqG=YQ*+!+AyLTg~?
zz}H+*qDR<>=5%UW!Y0GbYJ*7)tplvL6wxht_r<X@W0A(jH|&f5>l3<TI-IY|Py5$e
ze#=`ARBS_biQYx29hbb@7by{vKMKF|>|3tAP~1!~`B@rWI8_jY)b?Z9l)!X0Y!jG(
zF}^%InWrfL5k--brh$Q`#m`1(^K1@B1$y9ZXOm&REU0vJHaGRz<``31P*z{Fj=M>z
z71YR#bUlRgAKmd64#!8i_!k^h<=s->N}Pc{`ZOLGP<wjT&n@OI%{*Y<J&!|;sfwaK
zqTDqXu%M_E3a9Q#2Ox@d$8-`12=Eq4%o>C!vEa{3041h0B>Q#aAUupY<vtx1F-AD?
z9Et%g3L!<s3<pIV!n0s*10Q<Pfau6adR`OL{`gUOs6}7n%B9Iw^V(BW7c{KQrNDyv
zHeGXfc=fzhC)S3x)F`a0t*K#jBqLb5ZIP00-aIzy6rC@qkRs|s6oDocs|dz)OB0ec
z6S$X}ujqcR&;*3nwzc5u6zA?*ht1yOeJL=dfTA?sLJ^g)bkK+*hIq(Fh|MYsGA4na
zLs;w_`)6Yz@*z>dk&6PAD8%D<t~#PN1yf?=Bd(ll`dPnE5BW><5^}(KBI;K1b(u9L
zj!)h5R?$p~I<%dKUFB7;-GZc<1tSa=CB#5;Cy6BdaV3CcfeQRn995fg1Z>{Cxv6<z
z^Zk6gW^8jfWUoz<c{1GmkNW!Q(b4H3^53u-6B4?)gz3?d9Xld09ra1b0_4I{atIjW
zf+c1}ZM~~7ThP|y@E?-8U4^t><A2ZW+;tkRbGcj3Y+QZrifLolIamMyfDnQl4&#uB
zC5#S^8Cg>`UXYSDXi?_L4f|v@S91(MyQv{cD=HiBygipsP}7kRsm_|8-xi0QE=*Ky
z5nFtbD9(yvD`y+0nJ|}k9P0M(R~s7E%&SRBopd*T6^$M)l-&weQ(2Z|nVRg?eb4p%
z15ist@^&E*s8{ZDcB`739V6tkKI<E+s<yT`Z7ru|7!D_96izF!;G7C|Y~{<=wm>YP
zZ`Bi^UM<*O9l(NpUJN<Y98TJjmH+;|ER+ur3kb%HV~kySjz8OH!;w+aj#1Io+X}cF
zS662d3C}8|0(pGK?OrW8!(DM^h2%K5X;pdD{9xCD-#i26B}RNAX@U|gEf8R4R0P36
zMrhzT5POw<R(ZBS;cNaZ!3Wa4Oe&w*C}s$ddYN1o1*?X(_@FaT#!p#JUCRz_uOE&t
zrYSxXCJzc^<Z43muoarzrlve)3mcR4Ix}15xROzQyuZNshHTfudWG+`+Y>$YK^YNQ
z8EMSciLZ4#-lcf<$&;+Ywc^4h{p~Gn$c~ZS`i$x+a7nbtYYQQeGyAgl10GoD%me!m
z5dtuioK}0Mf4;jHp+{q`lYS5dhAMDL)2Opu(0i+C|8K3`i@oyiNez4_dXlZFBJ`eh
zzo@QzjDxf9OSOEJ@p$RYfZ-iP?x;xHw*N~m!J8P|0Cy=kkN(51`7z;{zLSLhXW*Bl
z?+yN<p?-=nA69<}ozbW$Enf9NMu77A$LKk(b72*`^hcwBi^fqdS(n^eFW^k0U@iWg
ztxyrTm4=l<fl_B8$>OBe`qm_|;l>OR*z4IfO<{r!cFbYOI+w9Oqcy8Fqd&_PH_lLI
zq^T#1GMZ&ew`JKfYy-Nc)#hkxt#l+mbL_-YIt_zzLv}iakm5tW5X6NNaUq&n>p0hO
zUSYaPovb>x;Ut>IDh?mTtEfl?^NI(H1zUe-^V(5f?@p_AQIlh`mA=-nL~5v@#`%Aq
z?ZRZjC{{!bh#^Is{Q`TP9t<gs_i3kmx^bNZhtG|Chr~+=lu{%tK`yGfJ^fCN*b#?R
zM1z402Z-xPKk2xGFg=GV>c{meRvDC0nBk&P>sSpE`QCODp1Nay=X~^A+RteJx43iu
z^yo<S59ky1S+=S6OP}1mq3zD|8!*bM|K~$_KV(LVzeZ0*qhui<giy$WuwSf~Ld>#S
zD;!yR2b<#v6Bu%c{7^VqKl_|Ou<5u^kB}`3Fh7St>RTs_D3?806hMB816Wb(k1%)w
z9>t$Tb<OC=51e*Wu-AT}JmcVD0!l>)I#Q-tHmewLl>w}2h0cWn6BauAOae!Q4cl)?
zm(}}ejQ-?tEXy!;T3vl*`i2eZm48d@NBA@{@$S5jj_Vw)<HzWJS{=v6j{^XVL61a)
z5%q?AVH7575YiA87fKd!j}bZrNuI*mS}au6LRe)XpqJvN8HXe1357gdro%hE1uxc&
z-&5ioSQtkcUu87}UGYhM%BgQhsh&2%vu(54FrRtFyz|NRF2EQHp$C5aF#?eXpw2jX
z?$&WdiR|4orp(tSL|`HCn2q@TZucha^WjaSqd*(`9H>nR;0Wf=KaZXm7=TP8W6-2A
zfRfKf3ie?ahPZMs9fDXC*@p)$)>cu)R*fPW)E(?3<11=HOccd;2h6M_uqb4#%xUDf
z4B@Viil?u$9gvpqs1HjRLXomhqP1n>YH;GOQ;PBaZOwSpwtDrN=wPh3U-g1dd7gI=
zf-$EB3va=s^yVpY@h)ib;*y-XWt(*}GjjEo>!&Z(RtH~Y=49<;ju;?=RhbTn)gjf-
zf85cAxT{RaLNUjkq8Q1Wh()~46EGJ5gS=;G0=eD6_vi$HustP`-o9@i)yW%9P5yc7
zmMsrsevL-|&$v~c{JJKmDSI+|MNX#kAF7HFBrYt^&eu2T^O3G0%bYoNJTC#6k7qoL
z5%!9@lRB)M)KN{N`f)v`EerlJI=s4}L2YjOarvoJQe}B#5ixa{5^V9A{r0!>2kpO8
zH|T%n)JjtA!u-azRmm(q3SUO8(GMJ}%GW!Yay#&f=RW^?&WyEvolR*&BP+RIM@Ep2
ztH^RJb<F<Zz0><H#D?SKn`0Yq`{(s{x{2~ZfsKV_>(-S;C(l<Gj{;}$i{?iT49%?=
z7*MCq#4OZJ>gMQvVOVssF@W-mYClP;EG=mtY)nYoRONX2VsI{Qh~_TuIdrI}=8Ibj
zmZpJ$g&&#c#JTG7;})8GjFRsoHo{6bY#q-3X)q`657s~A<(&FySmbiL3p%?Ca=1y2
z9>~|WP?9>8qP(dgqcR3ns$2f)C;sQxP<?qzOX?@Bt#=%ik^Eub%0`MT{%0mv|KZ(i
zH@D67f)Cd`Tm{<rnD0<9KEl2S{s1uhgst%xI~UAE#!ed%^zp0O?wY<4?TaeB(}vMq
zA>Fu+=}zjxAQ%RF?Ap*>#4&o29Z5)2AdwPJzOG4^?-_kAoo6&7&w#Z5ZU8GuA@!Y&
z^J6@BIoJAX)!J8Tui@J12+nZnFE=$baG-G!zsSSQjExP8@VWkTco9^&IXB-i^Apt(
z2~$efztOa)P+4=@3Y8zwGXx@(N-z#dA&k2&=CENvqrs_BZBSPm)C)9#9G-~MR})Lo
z<ptTe6xNO#&%QEO$TwCe6~`!<AD%8K43sfWR)QS~He{5Aj3gx`Xjow?Ri~u`zfn96
z;7jz`bAKl6LR@fDc&M&qdyyDK-M&QuGy`2V)Nwe|m+&Eph#xzKRCG0H2bdlqaRMze
zcqe^Pf=KbZcP^f8h?3wwQHNh91UEjz6gGtw=haFET=6Gkj8gs)85JQH7VJ;;DZ?@4
zoEewkN4k_h`ORlZDITV~&b2zuor54%S)y7<9a4uv>Qq4HXa_B!bXzj>4lniWrx@ZX
z{XTt2a9~5@0)YI-1l_H9Uq1DeI(biJfn)k`+W*4qvCOq2BPQBjk~%+i=MG)!*eO~y
z)`1=!IeT_=bP>8ZZa0|zJqHi=EU)e9sl9OQjW>?f>^^;Z_vdM9@no@@W>Dc%o=?Tn
zqc0pf)MFBSrUi=D6aCoHYD&sC<|mn&_`Yb93%PoX9Ut!=pEi`H^>)R}8te_Vy>u9N
zGGIbJCxEWdm<NlNu3f({I)14dt}~Ir!62LetROPIB3YRgq`@i{z3Z+uLt<<wayyW_
zg<8;s(C>!_OesA1ywMu9-ZpOq!c#th4)6_s#xY$BHA(GA=@D&urt_i-g}tG=))V<%
z<Q4P7<}FoJ6yd@e$FqU_W1EiU2cF(w-U&_A8_j`yw|<KO`Iah%IcBU>Ve1$}j1_-f
znSYM%qeiGcdYI}{rPaM{55dw&tO_!ty<Cjh(jER+r!`8)S3kS_6!)e@en~@yQ?L2b
zB54Q?y2V4?dTUYKG{ewy(Z7po#pN91)N=*Um&<&99<UxsQdT9XtoKja-R;-3TZU`;
z%uADCHWt|+Q#3s6z!G+#haOFdKYt)TW$m$sg%AdOuC<NWh-KS+WgGD2^#~?R3?J-y
zj@mvjKrqI<#8qG1ym@Jd3gFvUT>T)%#qSv+U)us|Jd3ZfX-K#@?2va}NeWZr!b~`~
zM>RQkp1=2k`DDRK$eG`4r`wl0Z@x&}Zru*U?}FjoR>L<s-8X;C3TPxm!URc=D|&X7
zk^r65Ne~bywRh8x=*QXcO4(pX#~{^H9n~wJUcatMN$P~)&)sou(D@I~36X(tD6=}S
z3(i3`fJdOTn_=b-VhO|5urD;Rf1d}r0uYR((jTLePX!4tSroE6=<XkKs=58|n6=#w
zAw60sID6*ZlDq)sj`iJt!;I_2$;nB+vE5=`7gwB_*XB>8mQDmYg=>Azk3ED4Wucq-
z*AGBmWidc@p)R9t7<onkL{$@Q2@OGBV69?m)|A2+W#pPtOxzUTW<?wbsqend7(Zlj
zZRo*rs?XIIjExl*{52q;F6X6-nA3q9X$uAP2%(YqZ4M*-2wcceeHewo>8;7_^}4>c
z?WeolG8@QWl456~bUf5AtK!y5P|$tDE|cSf`RoN+(-1unB#8&9rJ@Kk#KW4QRaL`o
zq|H)n5qE?NqvWI}RYe#Dr!y865uQMZb}F`r-=c!D6>7CbLkc8D-XIK5@3bR|di;LS
z<DeoaA<X3A91G;mb%nLofmwlr*4oRx9rRd4#iYHIZ!pd2F)ywCv9K)=Xl?rjCRLPd
z=Zd#;CCa`XCh5Q)2JZSEkGQp9lt`yUL?T0S@6&V89x&5+RpoCZ??0Nlv3^`1pZe$<
z*jFt48d1~Yk!0+|dW2iydR6E;t`WK^3aC4&D=ktuD_j~=ib@YUhRl;X7eB<iIGg+g
z5gjN*pb{%6RShAebro1UK}477K^{gi1$AssXXmn3)LJ~&IaZv2Gz}*#dtRr{p9wD_
zQUM%uIb4kO`B-S8#pOXR6;!=CFrZSgu<-90C}n!4Av0?jPiM{TedXI#XzpYT_2TLt
zk2b!T9`A?N%|k@<uLWw`D)Y68c~zVG%1%R9*WiJE@RyI+LH@TZVkYVp8T}Jd{Mds;
z)|0~s&=IU^bcqJ#s91sQ34Oy2PB>lICFcMYMuvww6eR?(;|3&L=W=ASr6n@G{f@}n
z#Z7rl<|ciU@|YIDMZ=|)DV@;$Pu4hc(9jUo)1yaJ_0YDWUnIAtY#VYo?uzk9`lEV`
zmC`l+Dcpw~mQyfhVpZzFG?bJ2m`?v#YSmh$*F|zr+QHP^n&N|ZZpdUwkSw}ASD+`p
z?A4sFKEJJUQBuvK%0*WUoO1WwAGu@4#fbI15;O?|G5=&sH&UJY#dWyD7DJE!839=$
zky#IBcvkCiQdgJJ`kn6O6qNEZ|D8UgPIodD4jS9ROjnG%#6>?fSF`#}54gF@mM~ye
zJCVqJC3Cm9IBs))R=06eCpbHsw<p7<HGYW7qn%5CUeLf6a)fF!NZp#<E}nH`yrlFN
zwWC8lu)pJ+;4ripgsBm41-h$4HmWjeFg){2dy>RxP68&iVkFt;l}BQ`kF?4loeR0l
zB{?>sMCj5i3zdB@z)TOi<Rb}zH{ui?CA-}8Y0@4VLouN%|Kk>E2@+h=A5Y_Wd3m}y
zRhQiFU2NHC$((x26Z^ViOD8U0D--tb<DS^KaVaO$75D@Ps8sb-$=Xz_96U8U$Q5Jz
z&PJ9jiNNjCZj<i6-ygf8#l<~NAS9xP{0hF<nv$<>{(O1O-0`HI7E0m1-kB%iO0qQi
z5$i118pn69Xj;LGfEQ`{?gN)z&R9i$_{2Dgu;~d07yUUAbnt}9kOPR(x>Wn#4*`^~
z38`;y^fsqKDB5M0wyWLw*6i5VIUgI?vSw+mB(2`2$yT#wA;0TUqw5|@nlhqdxtbzm
z?~H7e!AO0>@4rY7d>7|V4u+s-_00mn;RKzK{c+Pwh`GoxX2v94WjJ&_OfW&J)X6Yl
z;8`V$C~&o*S!D1VVZqubU|c#19JHgH{!Cr7+KQ|@HgEpsW%*|Gjsy84K<5Z$*TJ+u
zz5jl|z?oU1TwPp*Y8^AYxg}eKKlS<Q%_iFPAB}P$-qN|McC+!sk!qfT3cG$W#ARI_
zmK3jwROQc{!YS43h35+(+f1<_22a{2-m<g{GmwfS^&KJ$*JiRuZRXmAx??(z??g7L
zuy!>VKQVzOtbaoBT>Fqmxdll#JtV8_sMy<|wTqxsh5*d?cpqBF*87^;$Hv-U-u0@P
z&I6w+zCspeP><xMZU}7i_vj+@$a-kZgQ+XUNo3OCF>Itw8aFaoRr%d089mdiFf&I^
z;_PCb4b%ZEBj%)40s{HqF9i1Aw$74U&D(qYi*;&Un|aGF?m*A_4V(dwHkl+_Gq<Og
z*PBR;FX{gEwf{sn0qU+DhmFZ^8xNf~Z;F(dz59S@?(-ATvpx_FT@?-U_6d<Mc7%*p
z=V&!20EPrElvPEvM-aq?)e3N#X<$G#v}}Ws8Z+kZ#&vzN-BmGs)Eec1_IlN?5Tgjs
zmHX#IKGWR8bxu{4`izWBm|3@Dr+Vt(#fwLd4sY4{``<&j_Q#}QaRHLKrH=LgvWaWn
zS%2THs-ZVa-yEvCwQ2o3Ys8njQcGrzwF#7e8bOM^PE*=RyTDO*j)n9{X_SYdr>BjX
z%`IwE)9S$=E8;KhnCaVl;^Y6lY*oNWgpp{MR7v#kswvfN@&DF<wp8N8zv)Tc<JoDx
zVqaSJ<8>r_6xPSH46hWuV#vPVN>ps8c8XPkIB?Vm9CzNDB{D8>)O{ZaeAIf2X&bUe
ztjisnG;yaW>=c)_cEWCc;n2a}s->F}3}vP5rA?bRKe%~wQ(4I>lVkT@u_qq|8c#0L
zlF>#<npQTSh&P`!A;&mgH98jIw@DlFcod7iNDm$v!W_qibH-g1E{eZ<eu?!)&kgI6
z=T-J~Wx>wVciyQ^p6u*YZGYBVZD{e$$wza;MKe!@2H$`0PrWB5C)GyNNNTj~LWcvq
zCfA9g5JoggBmyNM{Gf-Mp|NpMe7?C!pZ{4mBwZD*#$6Sr<C^B1R*jE6>+o{{z4|?-
zWIDo?lG1rzWm!$N>6w%QZ8Kk&bMjxMq-;J;EX%Gieyz^|lnkwkm$@z8T{RN9^uQV<
zOs>Qr7A+JAB!3tdC5E0jJ!%9^K@<{Bcc9p`gDOHuz9}g9<fjp6oI_rOW4Q=vpsH8Y
zePHznp9cysXgX-z(497dEhMNimc#ItA+;@gW$$E1$D|~^sIf5=>g*IBP@lreb<`F$
zL@#2}7dekfwL(#?00Oe1h!Hlh2Y4|E{)FQ5p-%+GEiVquBSU9FNOZzmgY|ZaVIi#;
z3Zkl*%GcHyW|o8=WC)cmFxQr&?G*5QL~Z0=R*QO+qkeR-Gi(aH&Xe^Tk(5QjIag0M
z=vYvdRXL3sDzv4i84i<ZF>-xHVXKo;A`U5T-O%MazO5oSHiVWN@)eNB#PNa05G$RF
zQM{wr<CeAy7RSzLAWg<L6i3}OLkuxw9!3m>D7AM`k~kkU*TuJl@&7NuW-HgqNbzy3
zMTt-z@y;B2H$y5~ab>7DFzYsCFKDXHDwwe-o2)nLlUvOJLdf2a2;m_^CXysKBs<ad
zGEyP{qS#yF;_>eiM|KzzlN?Kyhzha9Wjl6&lt>AT{^A4;NH#!}xV0R`byLfx;sMUC
zj*g{mA>%uGL*xx3=1Hc(ye+Azj-KM!<w7P)PUq$#`$B#8o=w+%b0l{ec>8m3@p>(U
zXc#Trc|=(_Y=@K(-lGs&rRP?Zi&6PSQKj7bfGHtW!=W2R6kS(69r;L2vsy-eByhS3
zq&(-efD)-jTT6?h#imFgS2%?vgmK6zqdZo@aj5iqV_tS1Wc?jmKcI)8SDUGaC{GNo
z1!_5KQ!tT7lEu#xiSQ_%<GFYMB0gWh(FdShzeWjm7X~`dFx1Jc0fiPyNS}{hN82c(
zpaTwA51HCkj>wP@<wCpJpo9=n6}|G1rq=?4D7Gn)Aj(n#K7_9mi$np!V_Q=q6)nf%
zEeTM-31W0v<kMLnMNF^MzG5=S)<}<MNLK542*hg?Y8@SmVQm<N@kBNaInM{T_w}{#
z9v7q@9T|3;e2N0X2b=2A`sw|C6nMN}2R)G&K9D{y0qrcBy{2HyX@7&dV|s2<c{sld
zM@H)xn{94!BB!!t3szjpP+a6$99gZ0VjlekYn|KU_E5%{7(y5UXv`#rDTvj4z3mL}
zb5ow9kf<5ab5qxwbP+c=)%TAU;vAKCg9i-v|GAbuz-@~=lHKP|S8ty`GIhZH)1xiu
zZ?6E?EnuvKB~2BnNJ$8Vz(@&6npYG>kw{1yvh2KIxa&r$NLJ!J4r5Kj3pwz(EJPI~
zkt#hb*i*Sgy(!FN&BPz_*A)KQ(Xu+DdgaO&g|tvKY`Dc`KQ7R1U>Hk2hz|w+b!KT+
zSHbqyYxyhvxy^pF^BQ4mJ%v#CGwl>>+fNuX_Hss0wrD2uZcRyK=94`NB1rbTpghP-
zhPq;oGg9zg?RzURy5Jxlj1S{5TYtmrIT24tNal&_?xl0?s`|u~<-Po!St(CCl%%7K
z=g~6sR(;me9`63UqyZ<}5>#BDj4T^jTf3<xL`EPXDht?v>pIa*%3E~Dbi`u=I!(EL
z1LexD*IctMu+jq-erNN0hJr^)gx5(3iG<*WwMDmJ39ZHPJkQJh=9*{a$FjHAA3Ur9
z^fpDoB(i;VQ-11{gv!*)8+8X0$hm@Z``*bg8nFWJ1Om+Ll9gEFF_tj3aXl<CgeNde
z_0_C;%u<7DM&Bp@LqL1PkYc8_09J?XtfhUHuW!=jU*K;kH2w^JB94oDi9cz|(|u-|
zu6@OH6<=Kh4-L5cF=UNeIr=?ES-s<{rq;5O%5|+!LfGn-kgw0r`oSy+p`&i|RlZUj
z-hY2&#~srVUCZfLiuHs_l*sa9-c(<`Dy*OKeoBh0i@iTzsVbUV^72r3IZNJ)#uOQ;
zQAk+S(6A``v0K~99xy^pn3z!Ur%$DvKBnyA!^#tRh~6k7NxR*(L?ASXvu;^M8GYC+
zQbzBh;7Ik2oc<PtBZ80=qS~<qFclE_v}Y=wN#nPu=1KF(ZCCbQh;--6XQZmLl>>m{
z^C{KFW5+h)&Rsh@aBa6#i>*;BHc}%|6|Js|5#E0n%tz{xJNKn3a(G|u2IrUg)Kd%w
za{)Y9eET*J23^^OSy<6@CS5&KoXSmkR?5}@lN$ykK=Eb^Lii;qNXn=Za-pdrQ$iKH
zOLA!z5l;w;LqLE=IORA5gd3_uU^t|PyajR?gbI&B-@qaMT?_5g{>;u@9TP3_`zZd$
zA|!}D63G)CNksS!GVI}KGQv5|O+j#it`>?_%y|wn{gk5e*mdK&Fa!zs;NcN^EXr3{
z8u9RkjkJ^C#fOjG`0$GfEKzA|+asAQ0EIPSCe!p02vVe~{TfDi3W5`0i&!7QeURzr
z6fpG18|Am<XN_$YkV(k|;*s3XfBx%;%1{~14}ZtQvV8RNe*`krks%Ui<3e^$;y|6~
zAS!%k-H=^9IkVC%NBv@8u2r+dY_&n2D=s5fXKc}(<xp0XfC=c~?vW~qREWn0|Alv=
zPI5{DmFRi_kAKIvt-fvo<^lc;pQ^1&QH|6n!3N-J|CRt=Eeb5Ek>~iEybQqyM!*Cq
zdy}S{Yb%|gJJsHY=?lL8I<>j86JedIJJ4p5@@U!Hb(v}-Xa?&QFhUSxgN!0T1O&<t
zQA`)!3q$$|jnLHJl6a5b!h7KDTWe<oT0YeBDXWe=@lDbQe7;1y{aXm$Pg(CBk94IG
z85Y;e{BHjfUEAhoue|84I{=m`riz_Pp@<?e2!%w16`fXt9a0>f2f*itv^J>rQ}3rx
z+Tot)hgRnG;|1e-e#G5tnG_88ZU8_U!Xf>*o=#n`YSx?9sP(-jU6a1a+%$N@e6rxE
zUU#&hv>|mcwLEo8>Wit=^psKo0hBPtTUaUF!cg;orIqxpKCD)Q1giyrkj}`D(2eTC
zhkTTufPld=z&TF;ZFx3blWy2yNM92}Shwi6P(3|$y<FWEN%~bnPR1yzEY0BNug+gR
zAI>PPM5Fea*cm$RlV#Q=q^hf+U}$@a1esIXr4_5F8Vfh~6Bu>Q1}N6ICx5Es7p{8B
zuwPYHvglcQm!ljkQJ1Su>?O7?B~U6h7AX#lAg2^Hifld?hH&8)4=En(0R|uS4FzLA
zrbBduX7szJWriL-)BdHkY%E%nmA$5j7S-ou*B2=Yq~a8b@eISZkgfZW>$>Ei^#5O{
zD;wOCS70CjUuTQ(*_!ydSv6(uHWYD*>oAI))tRQqO&2~gvCa!ue59&s<nB0Pz4T^s
z5u&!AG<lXzH#N-~tj#y(*gJRb>iFfhZMCRY>i#E4vMwBb6LHR}7J*B??p{EEIl6(-
zZC^9Vcw!9T)zF<igkFy+?<}<Bw)GK0MCj-Lp`mJ=RvW~z`~BcbldI`TQcBK&2EhUq
z3ale@AHDkuBee50C+*+LtCQuV$cIo+6PZm#b5ajC-Yb%eUYzraADoMWi<HE{UO;5M
zl}56}u@YnL*fnsR4YeV^Bg8w{RzSFGW?bjmes_>o=WnV<|Foe10+S0tU?EtV6j0oZ
z)Xzpm)=F(N2C=Su$|M0yG*&5}1Y&v2k5g>A(XVw#)w$vl63(=JFA#_;+c-js+#r{|
z-Z(u|e{M4xnEB&xED~HHyrm~9oPT5Jk<aWKsq~Ezz4WdTnol7iUa@_tCytQQ=?|t0
zdiH~Jlcd|HD9<dYcl#f4==?7@WF!goRr}rj+o=!|dnd>P&?O&YW^!b2!q?()v6Xyr
z^byJ5I&#BEcF@SL&#81Jm$Pqd>LKn0)b2NNu(h;R`4U^1@h=xz+`)0=FTifrV$v+h
zJr%vIeG8B=?H-rzx4@j?kj1H6LUtU##`POfUSkX7*@_ye9&dX@isOAmK#HuyLX*KO
z58*WYv(Fq1%y)zM`y`wrg``PAc3V{(aEvphuqV54{o-P-kae=}X3_dv*}1|u)dvrx
z(j}tuwYmfrO=xTRsA`b0!v9-3AGO5*PC#m@Lm?njrk4I`Q%kO;d3PB5+XCnSML@d0
zK9gRr{R}GYJ)vn>MlvSzO$Sx;vC%teHf914Kvz8D=9BM<98w}<j~WS+Zmu2ve>DhO
zm{~XoQiDn$U8pqycR@TeiJ*xbr<(+{6?TYXQGDJ?DGs7VIY?jS$K2`RhZZNrF3;cc
zb`M;8Y4;XTfU4L_@vC+bQf0O6uNk#sLDmnmLX~p0RhIM<*}8T4$+&;hv1@a)^@g=D
zS)Y{fR;J*S^}8QE?65xHxX;)A&uCA5{dgqu+N)c(y!u)sGG1R#^%M|`$sq@Z6i&v}
z&XP1_XKf4e@{y1P6e9f40aYe)i5&|Tb(EFvZQgu<wR=l9maMcC*Lci80VGY?x}aJ&
z9nkPd<p5?`B{=X{5ZU3wuY8DF4^53gp*4)c7LnxD2qWtj+iF$;1wKH_bRUo!Kp>r7
zH;Cd5L9sTpVo2}wK^*X-ZeVs<>myIsADDsh1Tn7);eh7&@?mYi@$FQNidFLDK`I0e
zDylzb?D{@S_``ivv`8@_0qs^S;17n=fGie+Cb$IeCF%iv`2*eN{CRe>F$_wP<^pj|
zO2NxQPrvRhS89@BGP`t9X~EbyzOB02VMwmpWQ!jJ0=&(==7+pf-awYU(<p`B-p4eD
zQmD^AX5b=fh6qQ#;`kVUitF?lKb>s+bR5(r#b<1u&HQGM?M(5qr4MdSfY1DPU+g{e
zh6mLpwK-X1s_*(V_yf}q6Sof7f%z*oSb~B}D1JESOBh0i@)WclGi7RoT?;_TCup*9
zpGc)U8b!Jd=(&wzikRO`LXtUYccWtwcByK6u%FeC4*OoI-POAJdX?khNL4Bl8Jb@W
z4x!+=XeeVy!WXbRNI3~fN^uLMW<b+#+cp5Zqo9wjlZ-@_B1Y>P&PH`ocn4`HObq!1
z{g`2leRjCV<8>9yi8pFlvcoic6ZB(xRof2AW72{{1tB~D9|J}7P?bY$7sb_0m~fo2
zjoq{MeZbQHt$CPR?d4Y8UJrb#VctCvd>)YZr;@3wYL8bmTJb#i-KXcTUR<0E22Ki!
z_qX(dj*XZS?v$b)a{;0x$|oKu@M~d3bt)OvojJ`9OQ#t*PJcAv>xdi0U+<PLwPVW{
z^1zvk$?}G%{}@@d+xcQ7Y<?)x`t??nKBON$q1tTOk35J=&F`C>r&Bkt7VbHG+G%><
zT#9q%<)c6V<<HAm6DcffGG=6d*LR|lnq=^jA@&%Hp!jr&a^Leu30rP%t~&cJQQTy!
zi%wuz$W;ICD7|BG#;TS^zh$;@*3#(5A<<9WT7ZC6vFCS}hN<^Y?)DC~yQl5$0O=T#
z0bPtG&+2;AYPfF2%W;hhDq$2>@`i(^9dl1Q8}|?co}w)u!GDB@neGj1_RK-?gt3Z7
zaB~}bjaOVJ0PBatWLy*6QEeWFUf_hLOxlo{dpMyVM{44veX}CtW-!JSJ?)rwNEYSE
zLlp@vCTD-Y6!=TZ<uj`4(2eUHs+gPeLDAkh@s#N>NK)VfGBQK9e-pE4vxCbPt*kh=
zag%NF=-IO?TeKn5|59Ry$NkG4s}(1ilPsDu7RDS3-mc2lun?DCWED^b$Yz3w#VI&~
zt&aMiv0yzww8wQTtp-aZkb>LzV5*B5I})`|UX!p6+HHj46tdY9@)M?^7iNr+9c^u^
za`xi`wJXUBA^HZ_wypE8dc_=8WT0FW2U7>vuA^~5)*QX2COuuZPJuJ9hQ<f_%C)Q4
zh?YFiGGy-8p$Q-@^nJ(<lZ)zuRAe7((IvPnEsbJ{`@V^09<zR5|Eqto$4bkf)gnf+
z<2tLkbLY-Zq%5sti-@f*8-{mU6^Y9{b#*#57bT9X?HSSDGQW}W|Dv5iX2cl+H=b(5
z1wxP9ShqyNIZYW|(FYeJ^Ap|OxvCB&!fuBlDY{5tm`hmtFu=gdfBR%zaxzbU!&YX_
zT6qNCI1Ro-wpG`GH~yyLKzH}~u{~akYC&TdH%|L!R8qt-&^}N#qc)Ap(a1`WJwhGT
z&l=iKN^Rvm0fk`+W1ssdE{U5R9@|=Su!&o|xPEBxFW-Y~X72etH(A(MQ1WqKq@*Z&
ztZFp-*b`s0;O10AO+n&*y>=`5Sf6DcYhb2?^Yd7Ex_oXe$lYt00CIuil9kj}+ueOg
z>aJbVMq!T3)*JN@d(!+~gKG$)GAAk6?JJ4I7nuhNIx~_T41mZHoV86*g*K~IST&!r
zm5=g<_snzWT8Z$2M>6w^g%wY><*dAxl$V@jNJ<vi%dZj%{SZhJKCBQbl+eq{rhE9-
z582j2LuhvT;+PqBksJO-iOJ!~iKw5`{5FqYblco?zh9NUzGrp%-@4L!U$L;k{4IU;
z3yNIWuGT--tcn;=nVoOzesj6tIXbm2MY38~cLbcP&42xFl5QIBr%6voU)$(l$YnhQ
z4)QBVL4Wg!<{67T(a}NOiyKOpIGUY!@bF2%t}04IGCLgUHxcZ1@ErdsClDqeK@j*3
zl0-|kF<Y`;uH=)<Nj4@RF3Ei1Ii}u_aGsX$IjI3FL8?}J@x`KxV9=j_l;_y2tEZLj
ztY#tu^KeSAwmKrT*9#qkTe}wh`qsxTnSU)mz4&q6bgdiJRO0QcG$j3_3x(BL8<IC}
z0CLYy#`@KMy`Rv#S-ExJ6?e-U>KYnWEOa+apnrreD)_7WR4rD=&OmFff>|&4rI~6^
zErcf;+?ju@coi-5dvUBn^H?a~O+XJbmh4Lkw3*EYf=cpqli&AguMX=3yESIzw4VIq
z!YqqlQ-}&?9|;eVJ=(knD+`j1Om6c83w!Y6UTk#$m!F(m_~)$!iEoVooz=;P6kE!3
zR`X~ocedHufQ)cczAitIZ@`%>=#^Ro2u515Bj(SN|9lcZgw(}C4OXCl6W^VYdao6n
zTW_qZHJM7+PhA1zS!2!dtdQ}_N*fd8f0`oOIzKF^W<*jli{)eUQL5vY<<2XQil|PH
znqO8vpPM8I3vti7v?_ejy$)SI+5P_~Y3Y6`thb^-DGu`+l<kTvU369vCf|D!lEx`H
z2uwe5CcRna2l03QfXcqXy*NY`TwD%+du?-7H9hSXFL~kbIa~GHo*FLeCCreWIKbbl
z2w&Kw`$2*-j(!OtWicEvTeO}*_VD2B2oE&&euXPNc4$pD;*e9m4zavu2WnTClyGy|
zB~$-h{9+i!<6*<9GR%Uc@$vYmnZ}A$__AdVT$n~1pN<uC$#Hd-0Le$DI?P;pVyZ8j
z<k0()d!xtNI5U#|rf&#O!zuyw4i@$?7briLS(!6`yESu+*(ZeGQ8KNvj~C2f%={+5
zuq;=O^B&J&#NM|I&Sy}93<s%P2}U^2HK-KN#e))BGn_R8q8LKtLU@*(g(9Pf5BY+Y
zR4~jC6Z5dt1JnelR7usdLlTwze#Xgx${<UU6rga7#03p#^e_*0BktUJ=-^{2Zt&v<
zgNLN~c2DdtH2s2d6lFNN$`>_n9=P9b+Pu0fHS>t+i1}?`Ny=E2zDj*zDOKGoVcyD*
zX~b}uU?SfWu;kM;7n*MgY-O{4OmOIyB(lG=T8c<8YLOOMMQCgpVrO!ud$CnxAJa&V
zLwLGQ^!)jj=fJ*5``!f#K9{e<cHZh1kJYr=8UK}1O+|nS4Fhw~Hq_8p(Rhb*3l44N
zrlLA51iR!A=2QvgJZg~xHTyk`UQDGzmRYHi0-)<_AZo(L)m_~I<xMQ{h=^AMHEEay
z4`g^BQ^X<BMbeR~TP(Z`4{mnI3?H(}-#cVkU|H%D8fnOn&`8}pA~&*cKe8jX!50tr
zS*%>k20kJ<Enc;j1HWN!NcR|`M)h|g$@Xq5uXc9MY0tm>T!$_5f`O*)**TLr+04*$
zqmpk7O~~4O1OysoM#c&^n4RAFvMuWCaMO~dV^yO|;pj`5{LV5)HvHG$!=Ln^Ul45c
z$c<?OfWi_IwnsJGEuMeAx*ACXnO;>rrFtO)LVuE`$P_w9&SBXQ`t&(<%Ij^AE!Eph
zcA)^0sRVF93AQ(e8hULF>(5Wyvl9TI!Uln-MA=`Ron5+Y^TO6@9KZUH>h0@u=EsPO
zuROj&-jWk*$ZLP2W}9_&EShq3`(D)A^V~ieIeP9Jsgl779y?T(tk_yemD$B9uSnEv
zxsOW74|L9Q5fp1{)OypZS&wAb)kW&-9yAtj?c{$cM#o3=p(&R+T=N{&B>e|C>b~7&
z!k}!UcPFC-;=q8qe}5qw7&C9Q9UN`i$l0^4tq}`lGHl>Vp4&^l63#$6ICCwiIBYKZ
zc9M}uPbO1=KJEYSLPKS;_LbV{T3>DUvA#&($9*$>jq5)<jO51Zmw5g3^g%xD`nYDr
z_8EAmW36gJ&*n^V?{abtt$oLQlF01^AYD*?Oo2b;-{>bXPlU?5^Pb_3@=*4gA`32F
zUgb5%EypQZ16CrFbM|8nsvOo&BE_#`#aBlBScZa^+&+^cX3k~;097n+Gl~rh9*DVJ
z@nG9#<*nNYBcy5bvrU^*fkiDX{frk;%zVR=!+ZPo9xl<89+cO~2Tzs6+M0nVZV#^3
zVXO6L>Q&P#CM^N-G&9T9asVZRo$JBWW0cz;2XvdCd;@d&XCu7FM|^Z(wY8*3eTCsO
zSKbRYquNVdUvYEJVmtZ_;FTMkE13bq(DKuv%{S)<FezT!;DB$UT2Y599_Yx4UF-aA
zzkA(7J5N7$0KHC!V5ooaA+@7(s7sJHK}S{O^(asJMq6*M`=O_P^Xp%K`ivoZ_l<Y7
zk+}m|z1qRU@fcB_X!&I0(R?l#bw4kySk^mNw1!U5H#awoms%I9E6m4qwCF>&ZMtrD
zCLKIt-{?)wYxT>bcvjwBn5lGPYH%^Z$<2t+9%m%^`h1pe&JTh0`AN7U7?H!eiL>|(
zWmV%Y0{A(Iy|AkCY{{6V2eTN>NpW8%?f;%j>JhT_Q$x2976T@@IIJ*F*gg?Lc*JQC
zp8ueo@Tw$9Do+T4btV?q#nR!|DyT8-r&s^5H)EsHz|djSaB4Vp*aWc}xeOq3zq%qX
z8qMQ1KIIzDpCdQ<xj!ia>Sx<6rtY1&3W1)ve^Dyj`z3S&$CeJF(+`W4ICBO$!CWsF
zRz=gVM(uD3XTr4p5Ir0d`{O$1i#s(dk&p5PIWt>eDwz3b3q(7bmes^vWMaHpk6p-|
zGT(MP@xcUihxnG`ZD;WgM2G4GCsF#CZD<z39%}wG<V@2p=fsQG1#5ual>|3{05`KX
zRFCZ&FUZ$5L7~|>*}kj8v1@i`XDiLHb9NV;@I5!In8_N#*25D@Q?i%|Y6YbFLDLxS
z4WRW+#(ULShgO3l9Aba*!z^3*sP_&}7fgFRD&+T1>y722`e`VXj+r}jD<r#$+8l;3
z%D|`=V%4wO4vjD1^V=7t<WhZlz4Ik^3o9>jXAgK6F@4h}`nQoTGDEk)&=r_MDsNQn
zK}2VI@U?4FJsi#PDcPQwTRKOVKN4XeKG}Kiy_ZtPds<@&x~*qi`?ayRcf4ub<Hl{}
z1r^}0tNl5f&Dni?uH7+X7hS37U}?!+|JdVLst=ZG!wlOp;ge-eEemi$w|jecK_Wg9
zn|<&@9qgyr`pzxygE$&WsP6!6|EpO4`}=}~glKwUZE^XAyRk6hI;*k4P2C$kVJ9UD
zRz6M|vgkNM6|LFSRBRvq{`*fhHyw0}J8WlQxg8!+`)!XrGB!#_2V)j=<@>Nx$7KN(
z{@AvdYNhU4Z2iRQsxwN)YnHOB3qTpQi=2VT$AX0!hYhl1kPRx9F#A#UjV>53IJ$L1
z_dxae;}DTVYk@Mcex~qIz0aRp^HK)Mt$ryp?kb}~m-$k4F3EVQW(2IjFGKwL@01KU
zKEs`TV4ETDxg9NNU`Oekvl#bP-5Yk?9DMKc8O$!Pyuu1kQ)txvA*;QymiN}XL|U$!
zGnbD>J35-0qI`c$F~QBwfccEVEqVCiB^(6D8{bHKw&K~e$jVT`_}__btKTJsG5DnA
z-9NRPL%h@Sar>X<%LfCwq!Ot%wQ@-IAdmTdUBDL5y>FHl2ACBHL^pPcQ~0W*0)GWP
zUv+nDg^Yc0^yo~wwVe8|X;m52HaAt0yjf+Jvo(?eVE-?R>N0Dq8#9Z3nGR<yiIr(J
znh-l?4{b}%l{A!Os2L@(`?)huyy6bILXT9&O*8uOL;_jkewcuTG#1_MqArUleya1l
z-J)36ATsUvRM#o{#UV4Za!(d(fOVEhOHKVoKORnnIGx~l*;vz>(t)@jzT`Li-BCG$
zgP~=*Nl~unbHYc!@_`wOXqn@I4Lvw=^I9Ilr#$j|mmOF<D!LiTt8dW4mpL5TaJ5F>
zDN3pouJcp?Yok)Vt^wAI^l*d7yfp4<qzDleF9Qel_Jq~-qPPZ8Lmbe}!^6W9(H8P&
zDj4b*eFpNsW-Mfx@9=WTx+_J74duk4;qq`qmg=*VQ1#`1QhQsNqlAtuzi^SgM(2L;
zmC^=1oh`zcJF}u<W?Ft(MK-rwj%+~n62A2b1V2hVa=5O<3Q4(-68ABK-S*?RW-7$F
zNt+aH?qJ!}EavP|=35lIosTjQwJ3^oMO}PZaDf%>f2+4Q((2e6P1{zqqi09a-v>}?
zxbzU&;(kbd*u52END#4$b&Kli)~D3jL6E$~)xq2VPh)k$aO9%s3te(I>UQOC$j(br
zPcn*THpOB>f8#aX&`?j$p@Y5ML-O=5f8WH(%-IA6BuGD?N~(Qt;U%Qlp%O@N&tk}S
z)Tkmbe5lG0K`WHn@K1!o2`v>!qPe5B5mmC0^icq+uq;DxB2{nmYBsU%4&DhA3C-QX
z5B51XQ~mxKpR(_A1@W%WKaXf(bTq;SABv+XIhb{KM_~F074zv7$}%Fv9wO+F{GPeh
z67hjCORlw8B=5DsY87G7dUr_HBtbF>nYBeZ)~x+{vR7y!_n9|THymy0Qr*NvV<WAw
z;n(F2>xXNbtF@@(a+|VY`o=Tn8f5*`OI|$?R&0*QZ0)5N2~1LYZ;X!8^~NTE*O9h2
z!x+vexcdP4A#xMqjc-Qdfuhn1_Vt}|Vg{M{8=F4I%BCZB_=JDh|EHRMunyLY6N6pE
z=g+})nnNe=O_-GZoHWzQBffQJCKbXE4VDTED5A9zFJmO_eAFIxekfa}DO_|MMYHV4
zg#>hrBeM8q9nt9bp6YWZ;UB|qfnZNtg@w?jdb_lU_W)0jT;E-HH8c#)Y~30u@-iAM
zFW)Pq_cADlCXhB1IiJCe!x&a$YSYf<+j;dw26jQYkFVsnOle%!K^574n1V>;_01oz
zR=UiF9$ofdx#Hbpx@&ohZxWNU7=MyLjX60PaLNmf;FGDsSv*!euU<=dkLUH<`W@Kr
zn>HuD<Syp67re^TcFHG`-hEM@FA5W)&hE%eeAkYG(|}41IvA-D3xw#t6i0Qp4UX;q
zt{4#Vx^caJT*q@VlQH6BFEVk5=;rPfU8N<RE5?i|?UFaPmpRXr7%9E4sp(}(jUU8a
zWqRqsqE*Q!;Kv7@mlmskt5sl3XmvUjrP1x7NWRt{%#EBIPLD@EhGXTTO?ny0g6eE;
zd-!lHk+w-i5#1?^Ut2yxK2!1&nHzGNa>`EKx}oLQXi*ktRogpM-JK)WJ%@e1B?60}
z-;&$qx%r?7-ojfK)vwnzRXZ`)74i+*Et|;cpJ$MlV5Ya5LYaELVHwF((Y+Auml5Z}
zG$kmmP7Jf-w>_SkX=rxi`1mH&v1?ZckG*yRv3_|Jc4X=T)p;=)N+u8jf#!Q-7>5nI
z>d5_5l+hyz!1=_6Mj!5Nh4M<wdR+p&3iE?o?0g;V|L^bdyyU@C5A~qBw?{F>RpM3}
z6nBxq$e`w9M?}+OuQeve{5C!%&Ur;j(BSgN$5SININbZ|ZBAJ_A;+jo%g!_}$}%d|
zDq>j0%sYfQ7RcAbgBN-9I>U}$y{_(?m#X#2OFdrpt^45*`}53df7zUGsSQ5+F4S$!
z&14fC#KK`b!6G=5&$hTGFSO^cbbE}{=wqxkp*E@6ec=4j`v!E$PROjESOW;MkR;B|
zOX^=41-T>uWs9=f5>+tRGV7z5&aI%fx3nmw-)s=srhh}XxN{RrVJaVRYMu5+_*J&-
zJ7ati{@_1i5HkW@M&GBG{&-uIHi>wm=+D&hKC)b{tj(y^zqq=(=&v7bss@@AbvU*g
zsqtXiOj=Bu_Wo^0HD$GTbvRx#oP_XI9j$;&3MFfu|6bj-Dcv!my-Gh0&Ygjko4Q2}
zIkvZ14+bvs#EKPBQL@qWUIioFqE8F8OE5+Z&y}*Nr&3284kD9{8*wN`WwV1KSOBD*
z{FjVLp7VDQMr>!RcPDwt$3*O1NW67}FrqDcsw2V~u>Rw7GpBUdDz52N)uC#$vm5)<
z`uo+6_Rn}S7$VoAQV<`;+U4%oSE$M|fy7~Y&G#?{>$Tf&J0G194Xf8))yBMobB52Z
zz>Q(`RB3xs@2Sz^8NHGa6rhhO*_%Qe*C(`${BZ%i0mi}Rr!7h`-8kJz-S0mB-{JR&
zi?OU3+dc0-SElQgNw7`}*hgIrAwtPYg#pzbT8xm&d;nb$GC?FX@z+^errzN-sos2U
z|Ne8sc#h4j74Trqp9kqa-N3;7eHDKvv|JhIMvWjnEB=nzD+Bk>{AF6~sH+=F?3sPh
z_yk9e`p3b+uf9r7bc742FyqxR=^AAC<6V8dCf5y^Sa&KyL<v2b32BG-?RO07&dJ-I
z;c_EP=s<AD(Z+%Pe)j#|pGA?%M!vx&w3`0(TArlWZCM^YSdK6Ci_4_$iv~|VvwmGA
z(`JLKH>`t>(4lg~z8v*SskZ3-S``_|Be@;<%u(V$a?*Rs3uKx<l`Vav_-efVuk1&2
z{F|EE%F5nLxa{d*XzDHbq-p6DY5oGn?c2Urf@_zK<z$amjb`V7D<>-*^YToqAE5mr
zRTOP%N~AR_sv2p_laXe7-(XXFO#>t=!%Cj;M$TUqDS$RoW1eo@JRONl=TE=8HJQhC
zdGTy6jBuNq=JGY0tVR7Fi%mZ1xpZ)_v9@v0@v3f8mmm+Ql@n;=?F-~HKD#buvAvDi
ztdIBqVQH~6#bI0e-mzuXSnG<4!-W7%a{3);Db+;Lo<2C3o-yV!+~Yc|dpolEppH<Y
zJGeRW`}Ws9OUTHG|16p>;Q0J>^6tkm9Kj@Y<s5)~QujnpbUgLW27_J}GEUmlnkGvi
zedIR&y2;zNYoJ!?T*|f9>ptjUkXgd*VG9d#BW1@mGitGNfWN%<jz$pmQAycI7P?BA
z_f*Cf{*|~UeaTlhXE_|<u)`7+dT<BmsbswnPQ!1T516l?juu}b%9K83{=HWe#f{Ua
z%;-V!<#Mw;Gei3{@pT!eOq&4AY_q^P4qI>p#x1sa+@`#ve<8<!{6N5FAfVN)2<+8+
zhJV9z@1THdv%8uQsSYw?nMj^rAqK+aJm>B}Wc?>`!Tg&8oS^t#GEVjT!5ZBwt6g#i
zX^iz~y<C_vnIVkD(O6#s{=PN0BSwxIQTg>s5hB>?LFYvyW37<Z{jGUrf#wHH4?X2z
zMvU`RdwbxZt)T7nEL=pf$L(b!Z_5YdySCXt@v3?zjC@;FPcj66Ps6f<qF=S~W=?Vj
z{)%DW$Dx6pjM2n42#SK9ayI1=!7VL0G?gSpa^P9(FxoddCkF6YeWheI_La;HU=JsW
z%~2<)IYHQ}fg*OL-i0l)8`-`ssXbCwyuE@Q<hZ&*2z~^c9H`>cpL2o_1@XGF*Z-E>
zWWbkywVA6f4bUGJi{6$n7S9Bsj?WkdqUAZ6<PKFvG7dFO%-R-PX6$M=!;F?^MZFES
zfk1plxa6Xg-z=lONDRIu_^sCNwtSDUjXOZu>35i``?UMQDmT7>m*uCezQXzdcEU$#
z&fcC4BlF~bs^Tta0~8jtecf{;u#@Rvx)?b2w8=NkAQ;~uaQpgp2N@lm;$91*lAN}&
z-89KQpjxRLT6_*|seFt^AI%NImV1gN_QlP+C=m;Z3}hyoVj#TO5zDB`ol)!WYMsb_
zOFrm#Hxme9;F0zI#X6l@g2FTZb=d4*#LMZjZA>U;R&tD<8Q>9%OXD4JW#@Q7NqITX
z*{r)^T=EN<Q?QWAr1BFu>@XhW{!eoFJd91NIqaGcYBFdz%n-wjclY~4;@*X{`m-|j
zV2em5h-HX)$gE~X#iQIXoWP#CqDc*@4$f9Jj3JQ=9Gr>{0OY`vhV0*aEC1CU#YX;j
zg(gYu)Vc@-&*WC0xqil-Es2`tz9W3WVn}X!hE`h8*RSiDr!MW|9Ll440!4X*&8#<C
z@7ui{Nh`b~?lRYmUJ*>k+^)ZUo1Ki0nI`=)DMil;Q#;)A^SGvFd~SX?SafQU^LX?Q
z+C>%IC7~;fp<zWt=sc&tCxH>1o}bfZvRZR;@Q{s18`rwx1oJJvHX?@+l^uUj7NNe>
zd})hG+LoQorr*Tyvg);yT8O3Bl6yGrrL)+ozIDP0oNefF7?92R{up9@{COx2CR0U)
zAeW5&cC}lCfK$n8FNhHoMjl#~_aYWrHYH&r#%;YHY;Kz?*W~U_<$*2a?@&q-TV~Ab
zC`)x?uty6TrqnLXYa^3b&jG~%9gqRDJ9~p0J%JpmYUKX=1|#GD7u+)K*~L@_MBJ7m
z@;#V)V^>2kS-2iuK5XkXI|2DRoIbaOCBg)h(x->I?S$y}cWr?Sb8@Mi8sbv{cZyFh
zp^z7q<iv99lbrK&N^ni$6Y)<Z*5GU9d`s;26{`8$E_39@7r9^Dh?v=5;9qw0ZC%jP
z^7`wwov9J6dw0<Kwc6UXUEN8ZNNVSo0D*`i6<I4c9gjY5FqnQxuL-}y5GY7_-?>Ns
zN(H>*YJ#-!sO18j|2h(!zyek9(+OeXI0$ZNanOF<!<#m4Vx<fBQGhL*Fquo<e~?K`
zW+W#__Awuv+!tbOuU1tIC~Mc#A<E(vI|w12OWQ-k_D|cd<3yE35#6G-=%7ji9m&2$
z<lw!?NZ^>0OGO@%Y#&?@q_u6p4WEC(2ME6loj&i5c_Y0!H?%M|dZVZ3$fYAkBRp*T
zX?>e1MwiWnknuviE3x%F`qNfN@v(6E(az_e?-auVF`+|Oh+*c39<ov`<{O`Hl1}BW
zXQ_xqjia(erPEtTz6dsos510=hq1BysB)QY25wAqQlF@}Na8DtulH1e+0q-yw#hp~
zCZ#~Q;d=4^;W0*je0EMkMompdLRxryL}K}M^$Za4{`^mMAyYIYVh?vlb`G<Jj#*g!
z@HJmh7{$pqel^Sg8PA@nXIxJ#kJx(1>^_-~RwSA$1*N52p_^6M%FNc|wRJ~Bt{Sv(
z_c+XW-PG!CHN6!_a{LP#vDt8UwCwmIRK5AI?DlN5vphd7tWi18X#KHWvw(=V2<SMe
z`DG*2Xm4FeH2t8y$x6^c<re+8&ZcD}pmu!fR6-~RHA}Bt=pG!C9oxGgI8d$EdFH_G
zs|JTDLbugeZ?#P=i2*S`dvmYQKx|x$3R*DHJu%zSTz~&#mOSpnV|VL^U>jq?ZSCmf
zg<ym}hxMnb%4NaRyLO)8nLF~@g~3mzm)CYnhq_%c<t3ErSFa|W;Ee1eK|d8IKAA}n
zqN1f$ZT0#^aS{wFkQq7H{aygvyl<evwgUZlp<f6!A@ymh4lmu5K2T+dwV{suGP!T|
z=YS8~8?9#GiG)#@h@yfT3YZm^C}D|NnPgw3v~Z`bx0l)~xa;-r|IIIIYRcp1^3=N;
zTCxNzxu<6HUt~Tznb>DcU{G&{{Xd(eyjWhs9Zp*<sMg99ksEtzCY3u`rH3eM#=_!P
zellJ*p5{77?U{Scacyo-;?Clz9!}Pa9iN21%WibCriXg&eGk-0Y`3EYw{8*aDPT2Z
zInq5y8VDSy&A&RIRo2m>i`J1#+9LxKhQ<(9Io{aXVTn-NyAOK9iQkH7as7XL=Dnhw
zb$ohMI}=UkC$D*5-*X9aQf>kpe>Py?VLr+-VpVv0991wYXZdXslt>9fj9e>&4lvqm
z2%%7QieNmvm<=i>q{1ab6=$bJv3|c@T6Bws6+OXWXRaWKpE;4;a=3fjvic>a9@=15
zym6#7^cu{kJnkZrda^U-<NKpOpOG7jdUA83v4{Wj=>9lCYL|_>0BGrMmBIEw?A$pw
zSZ{ab0?#KE^4<`UbBiC8{FvoK8cDq0So@%gp(a6F>_RUJrH~>6T}@XFo-NB<XN~Z?
zN6>>2AYU|klB93XuC2`u(0*uD!FTJ{r`%RoyX+%_|3gZZM^|6W@;7EcN*7OfP&6cQ
zhmfNC1VlmLfZgU%ZC)uA;Pn74H*xDqVlaBUt31oJs*y?rImKXe*Z@-f#^UzC)Y(Ua
zt<ywUu`MTkR!PqXddnj4v&3v+4*!<rA4;RP!1m`bmE(r#^<#LRD<}Wdp#AALBbmN$
z7uSV=d*NJyoNeBCq|&%-nH(o_e4Y(&LyX8`*Ff@O%0z|pX-jC&AQ%Hami43-XMXsh
z#gn{d_wU~$g%PVOhAFc)+ys#yck(ykZ&KUZJiJ&4FG<QMDefpK=_oGAfRk?G;B?o_
zk>RiUPXmvZXp#Js)#{=jx>*6av_owKC3a>ClCN#P<mW`LIenP-ts4Ij6ZEyLwCKxI
zM%cF>Nep~Hw_TNd2egG(e!wfQPDx;Jcc|o?zueDLBHU~Gz@Ypz_naY~o5L(2s^W7F
z6HCyQY-7o@nbGFC<=yTQ|IFGM)m7Eih-m+Qsf1Ny^>)n)xdpWu0unYl2r8(7(XF*B
z=Yyb?B&XcrwrQGeyvt8XDQJS_HG3Cp{JK%nj>9Gpkbw>V;mpHJQ2Z(%JmQUXnc_e~
zvi5M(%9Rl<M1tJ(A1ktW&&wBPH{8XROsI+}MSZyMG?gf3jA80<3ajg<7G!aH<5ces
zvE(#uDN<C!#vJlm#afEK{|7X)r+6ZQ5Rb;m<Q&KB3Q>vmGmf~o^uw*pHmR-gieY%_
zLq|0o8>-$ocI;7p<jh9h)IS^b$wWbWs$IR!P(aVTvxcXi78S`+fgBFy!qXCbxtpA`
zigTwQ&j(!M)e(0lsl0~`*|iXLeHD3YrDV^}x%Si6)gcrLWr_B%xxO*d_lenKZEc69
zBQviTygpNPMwNKlBV$4U1LB+js45*@mME|8@|P_{`OG+X)+QxZQ}=%YhADYUG{{)O
zrx*uZ8aakLnP47xSRA&yFvY5C7D0oR4=-z01GLzc>(n_&<8^2$Lkl*XVD|Mp)(^&w
zGr#gYQU9R83lG}fikTa}qYn<fuO~4$QA%B9un((tWsw~&`~AYX@xUH+OMbgk<m?sK
z_Q<OCiI;oui1_J4`;?OHhGNbKQz3n@qj6hoq_enx+x$#6`}EqnbE~kS%gZ9;ph)mp
zeSV}N6@?M7=ikDm3q7{<&2=gLqNBrPTsXVXnCh(Y@kkYR0E8b{doh+m%Cl1x&#Tyd
zE#&KXR;XYb#nk3-OkJ6bv$kOGLe>JG!0sV)5zvnxvKvH^1W<qg+mMfjT5->6wRYRL
zTsOG|n0^D`_Zy733O+*Ksl$+BCNuZlKRBK=U%m0@<@AnSKs=K<;MGg!!1{|3`Zpjg
zM6*iPC*7wQuiOTu(dZ}V?PNxntU2imcim&?5GR>W{AY7b&%oq7L&NPC;X&oX32UMP
zl>+)g-}!Y`U;2iV*Oe;`%Ra3Uw}IN)NN>->mLBefmVQDdFIDG~f?M*AN96g0GDBxa
zos-q?*`}QArbd{EE6nS9oElcPDA=jBxe`=S@=#>Ed~g^yzxKg~n|J~tG=c3?C7nYc
z48W{eqWHMY+?ho2-g_Y<TreU84hkN|;EF`mMsnyB#i<dXX4%<qSrp9{DvU>_@H0U+
zUGNPCR#a7smM{v>T5KXHOT%<%9*`us0nr|G#3J53k6H*s_gjcZK@z2cD`+<uh=-Io
zLh?{ATC1t(2kkUt31%w$If)B!lnYUAzv1J1jvqNDzC8xZH=wxWfIDNh2gc(+9p4>>
zla9S}qekp#g4YF^zMXG@1t!N90CVH+LNm;Oe^iQt%La2Z0tWVT|Dxv@sd4UU|CiFO
zQEU1^=;%q2dFc}q>i+#|V?*TZ;*MwqywT2S-~Ut^7DRTGcHH$AJ`hLL7@q$NgFIqV
zqz|kIG}NFU(_eq^$fAXiyajjt9Ue&_+O!Vx>&Rp~W>`iCMx;LA7@&>;WMmJtPLOIB
zKu&Dk(9lg;PNn~8;EKPvC74F4nL4_~F44BEt7}<RC+ukXG#c=MV7AsLu%_y%NmZRZ
z)zr}w?V&pz3PHv;+TeKZX@pOpNtd7X|6wS7;a#?5-AVIF9m-Gse})A5uz8MZWQYNG
ztaxR2E5y#AFy<b2Z=H<dzWq?UI9C$Bi6$52F!z*Q9e`Af1vYFF`UNWYPXtCW-m*?B
zSRZz2;IR)8v<}%x*sd~(>F?n%0fpM$DrGJgvgiL4-^TrTW5#GZ|ME3OR`sRU?0&Q#
zoRFxzdU?616mI9UEpg>P?Qi2&?Ao}!cOn0B&y$rta42B1_3$M0yRlZ^?n4{EA`G@;
zqu3f;KD;(aHX|YtYU?8oJHG1>smWyZ1i2L->Bn1Jwh-;@y@YEwI*HO)quYSu^*K3>
zk9V9GIB?)w75H2DJ{1-vemgYQ*ndCV=0s-rg?oki$~_#*RD#I;h@W@xGPziy=E?ot
zlb```tMdK_&hLY9Ifj&G4%8#x31wB`Sd2bK{)selA}TrZZ<FVAfiXEL-!xmpX-X;Q
zK)d9<P+IrMpp6@rwL82e%Igv{6W44!9^$oJl0oL!&`myu*8j@`V{>zwb8}*YB-V3P
zS${;F_}cqj-I5I?jzv}feITC5_J6MOqTU7n**9qc@6Vi-q6>WB$y-#l*>*oFdVQYC
zb9iMkm~d_Pl93k9;Paf7l_Sy7BfV@87oy)6-=ret`mlr1ym({$oWCLUi4^_oADTv4
z$2kC60Dy5D$-KzlB%?GlQgUZ#RK=qPS~tytSZp8$leP^bC~5~;3F~R2)_#k7ZlR+J
zhQS4bZTlk`K6axyXW24&LuDH%jUqZEQSm^b*N8*vdG9f!<A;;n{rZvzOImn4PoO6#
zX5W@62!)I<SIFC84$gu7gD$dm*N~86>t`tmNE$2OMduEkh}i-SK=+lYT-y7{??CKU
z9DCgspm~lwk8+HLkV*yC%MPS%AeJ$-JL<Yf2$1D}CMGPv{4>hu6#LaZS)k4PGb+Qs
zyxc$I$;z-od~P8grc!qz<MRdb(9xT_{8K9|MSh-7M$hgl@~f!!Pkj>Mx6EssU-KqZ
z2}2VQC}#r&=hWHoH+q`%6h|z`AI2&HhK@}22P0}{+L+cVvJKpYiWfBE<QYC4x*4Y;
znC`ZNN&R8O3hvZi1bQ}eo_Hy}HS&XjLbMLYNdOL9pQ@~_tik_I;Bz^s&gEq=KqGm4
zo<==?Z!9<jITNqTF8D6-z@$U14P}8&xKnmuVfm0Won&qCZxO@ey)!wP8S`_8H->p-
z`n)&;d1VLXTHYs|$SaeV#{lDvn3*J`A5(bLesh`zWj(TP*%BGp=VoBTg!sgoQQ50O
zw(<|6@0=Y{FLC3WH0Dy+m{Bta=jgi?ZYw5H+|Os%0PIjc3VEdPkw>gOnlRDd5Zq_!
z651_KT8yfbv7D2r*T=^>*R2zkm~o6;^}be<F5d&*PNF>|O7~HMeSv$5uUJ+ZlvUW^
z!*As34A50;ylB3Wbn&QFM-}OH;b##<^@ijto>rxpCluR;N0xzCd+tftlXySjDdd=e
z7I$?Y=<eFvZ7LFF^Cg*fgQ*SVg0KZ5Ted7<tWQdjilw_>GaYpdkxE%AJ1_B#A@xkF
z#PJZ`2@2^H&&(@(rLLevpeqs^@e<w4*?FmYRORbTM49xde?N|A3iP~kyfIOlhrXF&
z+Q1LdHloYlB$z->1qtk8j`S)Ka=F|_UeuFRjV3{*f>n6lb3AV5_y3Ja|NM_1>?u7~
z8dES(XxD2w*;})7wq|F+t6y2HpY%i|O`g*q=<vOCc$`oLBvt2Uhy8vN=@oe!ZC4l1
z(Uc$6nb)N)oB8aIr^v8hex;k%uU8>}HQIB-TJ`r~N_EQCG}9}!)20Q^!i)8-{5pHD
zCJHVE#3Af%^kSdo&O3|!0@B6j9k~6|1M2?$0a27yNRopi7+@D8GX&Ta??&Ezcl8DC
zpxguS-7d#6)tpuHR4T~*jpM7U41cN{R#16+q*Wb~Bdx9bpX!(rQbWPuegh3hdwV~6
zUwpAw9_zac-+kBH^YPeNN~k|DD}cQ;AzIDW_f{Smde71J6CNhiU}y4`smZt&D}#`4
z25d`nxzbO%i=?vm?+bZzc4qv_oxdvGAt)2D(vocdQI-+|S>$(9Mc<bR5Z~h=09vQW
zhnVYU7?O6-O%1dB>%5KzP_8BLRw}8pm*&?Q?A+E12f^5+nz9coa!7`uyK_Nz{>b5!
ztOosOp<k^v=urfHjAqb=Ig+uz^2lim*?jMFi2(H)jz{rWeymeoFf}`1{ZjtY8p+;O
z({gtYbS{v88n|Yym20iAOt?b#MJ`^vF?}&&er2q5>%$xVFIwto{qpAjt%nzH_)SD&
z{*XVmwJhVTyZL2n>vC=VjROsSgzK_!?PKy)vn{jm7`YLbA5YM=Tv*Ot=UdLEobHi%
z8^|PbGRg57=N-4RP9j0YdEKj0CsUWpE&~fIpBt%>$2j0|xz0Sw^P<oB&;Th}>sVqQ
zNgS-*R?YHpF`BO*OO;Z`^j0Z#pJ9nQ-44gT&5|cufdIADYG_uPRS>x{#>=(5vQAfb
zxa4}O^n*sBFfv?&7aTHea-l_*-B5x8q`eO$x)1^iNo*3Q7v*YI91L71e?tcb)TqI7
z`$BmeUs%Eu5B@m)%-XeW8Tq>Wj5o)E+j@HDp6$RML2F1@369#Lv-Ur7Jz4S?l%9uV
z+no#3kpp9FtC*07T3gm1X)7QJ`pTgRFhRnStCg+_4<tnSp?3S>ODarTC(RG+Vi1D2
z=T3f%e#K#z$ZAi5)GYStXI>-y08&8VDJrUC(%IPwi7{4dT!6LQQnKgp;P^gy9P0Wx
zgSQyqQo+{yFV<Gx-Ej#vvmo>vG)rR6DWRu>q!R?eAh%^IRJLtusl@a5#tj}6Mmz$Q
z5Ru}j$BQDa|72b2-QtNrxc>7FbT^(CrMOUMX-Ii_MLLnt-MRaENTt2VwCV_tN5u6v
z?s<oUEc+;JxHKH*h|v1@@=C^AM*dSdue9S%y4VXJU9E&5krD9v!o0(jZL!fxBoHAb
z*jGZZBGg+ILHH#qo;q(vFC?_;mS#IwD71-aN>zU^dU-3J9i!tXSR{1IKHu5_J2<oo
zbJ)NrF57x0g#BVpbYnynW>wiCb?h>ty9@@Pu9ffkI6*jg`YMX1uPWlTocMk)GOI_9
zA0))hFb>_umrc}gwv>aK?jH0$%Y(GbGf*;xCb~<-F^l&6@hcjdejLv&DDLV#_D|v!
zKZU%`GCyxY9QqVlU;MDIeMI1m^_4zlK->R6nk3#^am^xtFRzMlS6$3{?Fu|1g<-aU
z)D@~&=AT=>5h!lv%&RkKa8djTqqH~fG)T9IcaN;2`71uZ{hw(NjbmV-WjceX9^hpB
zR8h<I6cjrCuTSYR8a$GL-Wo1Ie=EAcumh*%K5*#L-yrVVR0>+AIGBL&@MH7`Iqx~K
zbkTx{=u`U@$1kOvx(groObO5P-*%79L+v{p-WRo=G3*@+M%gs}mlL_0Ew3jybW3xb
zH#N40dt0Ow=tJvJHw(o7Y@f%Zj%;iK4|jIAkW2Z@cHi{O$V3K~1rpnb(_;<{72q^F
zw?hsBOhunjcbuX$3FI!UQ_sF!;G~CO6%&syT}MMKb5jCX8OwdoT9%v=;zFe~^C4%*
z&QR6)NGVd?*n@irG<<FPPBeC8*97Qzr82dMw6@1m3bCwpkIOV8Oh>bMaODZ_Iv_qz
z5zyUSAr!(Rpr9Fov@h4C4fWix${t1q<)x?mvd22hV~C6T|405hIeGaHqBO_mO*-y4
z@#gsWqrz3%I%bmFCJ{t=4o2bFns@1dvDUo)atQ(jG)gM6o+#QS;j<Vx#VSTB$_H9;
z8DBdW=0#UBe~jLjx|iEpXmdPjDg>jicl!j2W>PG6E;d3Dx=D+%SN39R*OTDQu7f2`
zT$(@U8&=xlql=4wh~+O8xplT|eG-wUwi)<2WY;b;3SGgJ-Qv;#zi0E-b(vCEVIn*M
zV>(?|#8lPQS(RtKVKtd%Oy;wkpv<-9=e19F$PDVgQMms$lfaYwhBzxfNcl#nM+Z%R
z{@{cE{!8<jI{hv6qhs2Cvl|9BPg~V6j#CLF_8todtpo60xuNU9JuzQw^f-GO-iVY*
z)#&AyCtrHmm@{X_F!PTOsrzQsY!#p{N!a&FMAwUYb)UCxZ(^DKj3?LxR@@8xi1hU-
z2iA%Q4z5{yQ0WC1DmH0tpuwGn+}d2h-$9ZF9Pgw%`;pJoBS*p+Hf05-YepaCw=$~y
zLPa|#zej?KZ>WP_4v8No>ZGKH-Y{5ZHY#%3uR%A@V4f}H3cbGzCK2`8z!1hdiZTag
zw$N`sVqkg#INr0~x)Yd<8-F$W_~WN68o~(P^fHro(_YrQU6pCyCUJ=Nx{!gNSeEPz
zvFH{bdGyF)q+62g3<b25Qk3X!MSIzW=v|x{3=u}`XLE6*%gmlz(yi6yAEE@5V1N6~
z>XNtO%i_^JA{}oo2&^hlzLR-eAjtKv>0yOk$j5w`gnSf%3tGH(P32!-Tqh5yr_@)C
zGrHbqUdB(<<M&6l-!UDTwH(|P3?d))Ra|7ovc-S9=99s{qQ7qS4A6?OXmK7}r~3RL
zXe06ldt?v;)S=*b6Tt`Ar#B+N@!$e3<v;M!{r2N4-<^;3Yi|CNnP)ox2K-#FadfS1
z<qC&6*$2O=j5!R+AP9mcAf$X{)ohqjs%6H$)gWFFx&pyIL7L+s`0U2|l~71x_R7ln
zYVjjUb$@2t?V#=H=V{|+<s;-8*_Ni%lH!@wR3byTWJmg8$~pGOupK>f)HXiLJv+v$
z@Wkw%hz$|R*=4oTVtMt(i1iUk*}RnvU)FtI*Ff?^(mXl~iuqvij_LuQ`%q7c-h4OT
zZr*=So&YM%yk}2iZ83hxwW9c_|J7+x4B|}5BpZ}F7duPL+HdVpZF}t|<(`s?7`^o+
zR-d1Yep>qf|3u~;jg<Rt6u%Q4uX(X}%|3U*!oqobePiFMd0iPOanfg*7Yr^iYt7sZ
z-mIxC@u2IvY#2s~3%OJu3-o~Ov9`9ETYWlf^%2}MRvSBM+Z?miF!sNFTarhk_g)+w
z<Epu~YW|V?W%^-$Ix!9}3`eIv=IsMJBWL25r_v%yX(Gpcu(nG7Z+^q_-A7`Bdd+me
z$vR_hs&K?^EHE$X$B7l<av$vm=stVKtXTls2+Sd-m`flS>x;&=^})l1URpP;T``A#
zcM^PuSKGouf)`8K*0XT~@p%T()<(=}?d|F!X3cW^GQ+yn$$=*x{^XPT`i{g=+%|)A
z)S=a;>FxTInpUT(<s%~x+&|_sn2wnPAfrOc6rs$P&c+`~Kr-W=;srW_Hg1HRYypNN
z|A5(kH|~Csnhvx4xENOh!R*?DV8S3%?i<m)*G%`+SV(|+(z%)n32cn|7DxX!vso0i
z>w#PNZHAlw5$VXNt0kcmqt><w?{GUv)_>1@6cpqQ%hb=DAKQ0+`pn~@v<74KYj0%~
zXT0@VwL6xwjP+^j_b)1L8ra-iI#@hdYDojnr%&O?1R3%We0U@hyb!b_Ou*g8`7HX<
z?Kk+k`mxB?{k*QeZtTXt@b2B~*WYltcIQU6h*Cs~DbIUE+3yIw@kYVES9eW@;2_8T
z{bRB`eS4R78*h61bd@}Ia9!T6nNsrSri|*9lDJGZsSFkJO|<(#90mEdxeCjQfk?>i
z&hOOq*@B|_1nnKJ*s*f9+z85}Z-YGhf!GB2f#|x1X2j`5I>yf-BTKubXXnrVIrz@>
z(X{6qz~~*mrg018<$S&pcepnTeE7)?<CoppF0XBExyd)X)MWGeaWm!Jd%S8RS>yO+
zmdR&I96hr9$%TTx{c3Yo-4x=NpZKt(<UF~XIqhNdWI*$={6yD-dQyMicHQOjNUFm7
z;;lPN<Y+Ms{^J}$eMot!wX6tVj-?AXakx=jC@wM*cVy1wX4Ox$qxzpZ8h#qnzfNOs
z>Rv!aBx3gyN~lZ-nN`RHvD5hb8`w!$;zEjo!@e-mLPWExUez`{0;AHAnaFO22=e<?
zNnNe{=gy{@4NWx(4PB8LaLhAC1?P)e@SHx2`()_h{;yp=>T`Vt{dJF_$oaluz0ErG
zdTn?2fu5e_<?S`^ovQQrkso;~uB_00eoet^o^!XR-dUhq+_RERlamXf#5gD>xCR^K
z0QS#<S!UeO>UC`0A-drXuWul)ns1RnUiHL62#j(mqs(<5ALZxOE#=11eerz!eX?|y
z=2Al-QfZ&xA`kI8iuS$9TjnDf^1GP_mAA~RezU%NVm$_s(w1b<->8I96AJ9-5KL%L
z=Fo~i)d)P;YWQ?1$1VNT@O}|d@i}|eVs?9OT6uQXn)0mN^0b`W4Q(aIhmzo>iG#+K
zn-ZRIiLba4V}cVO`ar@<R*pI)ICCJ=WssR-6DQ3tIku;T(qhYV)0REl`jXwrk;xnT
z0|LH|#o2!*T$qHx1Wy2?C_0Z~kbIJ=LZlD{W%^7biSjzjWIrzS>VC&pDJ8Go>bUl_
zLzcF3r=R<D|MJoOHOShE>muNBL^R&OMcMHIg$x}yK@%NRWoKz2Y|aNDfNe0jJ@%Iq
zfr@uHr$kATtRz`U#nzNNXMLe~qzlv5*NM1O;pm&+c)$*Vwc$u^HCqwj+rqBqx)lHM
zZ%mw@;G4&BR*uUf{6{8&wsSuTMx4~p15PBR6$k`Iwj#KRmA&o5jz!jI>>QT7Y0<|u
zHP<9eeuU$b3y~DnSojdxpjjPiXpr1|8Z<65jZT^Q&!%1}DHG9(T`*tr!p#vip`4{P
zL3XlIg`!ku#|~{o(5BgpuyRd|rkq6s6DQWy6XgaE(mXqNI<qJNRS=3)PD^yta9Y5Y
z_>^IIK<OK+fi>T|6ekSj-Q8W1+=wYcnwZ=%ZjV(P9P~(-fWve1!=6CqStQ{>1CC$~
z%<t^=$#1Pta}NtDj~pR5=X;8ME)nEIM3Vi!<Ogfj`=lYQ7bho$5b}#I=5j$SCcAuW
zqpH6saJ?l_f05W@Y4(lI>lL#qTwj*xwOL^Yl^oZufb7FQ*Vw4}y~OUj^Az&bF|4PV
zd^^;cBbi+<O8V-zvNY}0uadeaA^#W;A*$X^Z|*`uxn&XDDlesX`>$7?ek=Tz>FN1#
z)<^7#nj0RiKCLCMHu5Ew?XnFEDqcH$@1=oy35T&%KXB>Z;kCtljzeRa5KSz7X*S>7
zvXs|&iKiA$;*kC{I14ODa&p2{59#sH2FP!>|0zFnR^#ape+tQ&f~n4a3*PjK(QgZ6
zrpF2T6OvZd$fhn?wll6(*Y%(@J3;^0cz^e+b{h3NqqL!Oit~!wG@=5!yt9u5hG(Xq
zBdRK=b(e7(ejeiKQ;c&GKbY=0-@@0!_+KRx0wd^CGPyd`$5HZVj32wwXc&n=q)jvb
z(H#}OP6HmjXpv}WWMF!vyPN3lZU90+y}$hN(4o*l<*l<q1J{Z_SJ9oFL?{8xBf8Nx
z{<?39=Dg-&Bl!h=t;_Xh=~jbc%(nJ<2K~O_XXC~u(A8M0n%5~ep4Z0BXRIc<S+u#H
zxI>KDXnf8R=d-GUzk~F*ERSX7B0wu_7<;0moezv4QKco0It7WS1}}071_x2VgurXG
z`8sB0S_dbv{8CC5=*`*AH$>0;P)G<9zivT{TJHpW)F7ueBtWrM&}{CC&jV8%FwDEs
zP++wdNalErc{dk*nO-*F8GVFZ4xpo*M=vq3NS>xvPfGxqt^1W;7?SaqpoX&02`@;d
zJUqO)@x`@ylP`MH*3O{xUZDHMBn;I!VBYEc`Zm|wUl=k3h`^BX#oMm7^&8?LTj3i7
zP3WjHCA_j-^P(+*KNyWc=NON`?z?NfmZJ2oQ}Cl4$M{Mw6>cW&RB<ynLG;<Y!hHYg
z3W0o2QpuGS^As3jONk@ipRNA=|Jzp;?Ckmd#<W+J_rniyNVFN;!A;#JkW6awb8B-t
zAzH{Ibw22a43wA{iiIx^w*L(rdMjT~p3u{a@wna&T;Y}Q*JXn%r>iPWAC=AY;~X%J
z6V~en-CI5i3SOad*<#+Avd%?qcWCbML`Ca<QY+`H{|p>{!J8{upuu4SeuE!%do`bR
z8=Rp4m&Rv4bkm$RbpEl}s!F1;U_MEWp?ptnt`iEKYb}2@%vV0A)EiZz2x>;yTI8H{
z5h)tg5lE&gAJx{qO>YWY+UPywgw&y%^bhZtSQTaJ*=t?aD{Elivj>?;fXd^JjZHV5
zfu46JubI&>?A*SjY`5<8;>W>&2c0{IJc#N$Qm-2Y5K@r`2i^3m0T{;^!gkTMYPdgH
z>l0qPvbwarRI2qVVYP<dsgwdG*%ioo!)iPf4RiUre1zm<?ad!?^YzZg#xB`OH%K7c
zbwNAVx+tZOpS|#&O$`m}4ZmN%e*Iy6eNAus0bdIsOcVjU;upGeC>G1ISycCB{T+lU
znwK(8OsEf28V2%6*Ap^`0f2pM7!ts!bSItR2}ozRf9T&rQ?adK-duI-88VU83a-AI
ztyIdoYnpDgL^bqKYueka^4NYdG*X4_mTkZ3c_eQPM&PlDzBWj|Cr~u*9icBl>jrdO
zN?8}7gBgYs%N5cZ6kUzQc^QT7)Ix>#0FrWaBQhKg2XHLLn%Or>`ed5U+cecp3<YTz
z0EJnwF+{gi7T$g4{SbnA7UatYUAvHa7f3O9e-NUdR+oj23;Etzo0uvI`pb_yb7ydf
zeI$uMb8DC5UJrx7o#JY1_8b#o?GvvdzWS=y&2+N;nLg<GVrb#NiW^kgVA_9nFzsrw
zEsWJhBasQk$`h%#F^q>rVRL8yCB84T$<Yc4XO_ZFwj&n)efa*TPX+PiS#5f02=hH3
z#pTPEeaF0kjGS1b+c?nj!XzqpORwoou4w{UG%u*(!SiQj6QG7c9-u;Lb=CHJ@7?=4
zwS10qeEpKVMq^xWv?Syhz?DJ{Sj*+Kz=UhQto!$g>qVhK*dgi=qQ)|^<L(u8U$$hm
zB)fmwc7HJ%QF!&$3RBUg?eT??H$QRz@burcKTQ=XCcC+D`?keBJB4|#dN~ix91^g7
zUE-TZ7I%ocnKXRi_LHY?ojaXydhq3*7q?fOzZrRR;UC(VQ=!V;{G31FA}$DB&K#!W
z>BG!4O>nJ;!nmD7>tJsU(tMh&=Nv+f@(EtHzbr3FKZ~PfX*D5E!{^>RJVBMoXR}}m
z6yrwR;mPj-m~e)=>^-w9K6Hb}*e$_Q{)ec#Z^Qhj(bWB!BCG!Um()5k>|nb8%7;TH
z#cqEbl5c3+9>hv4tGg}=oZPaLR1~U7vY37h!TLFQ;o_D}5H(22vnSa%rETKjGf06b
z6z>#y@BM8V=^Wk5`ukPBweEoO$;62on7Y$26PEC)EZfV5R2S@`ZhUE4<yD9Z71v+u
z{6sIvi$cmHHx9ywf6^R>QTQX2i5hxErtV4}1H&<B1RGo+Lq#o7(t=ceETfkunX`V8
zkfa+-v2D^OHuIA7&o|8s9yl>I;hc2BB|v-s07MrTU~lWEY?!oHp~I+$FwD|U>@qPx
z2JJ_k;(l>1yoT;4k$rwaRx_E*f`%`JP7Qv5u1?{X$=_3}<@cj`iU*<I+B!k&ux+@D
z92D%gty*pciX5$X#pc$NPYq=w+YyXlh0Xh%5(Ih>R!xB```*MFb&i}B`cHT(bFe6r
z4zJIgboYuoKJt9DO~i_y%1@si3O0z!1Qn@!wPN{Y&>aNFT8<fFqFmfGY{QX4weUzR
zSVeq87O^ISGq$@p7n1pTH7KUK97x>b!<dQL3Yj1;d&w&`)!3CFVup!mxVW3l*7BxB
zn@lXzxM^gK_E4F{($d|1ccSw~XE(EZ71kCtItn&Sk_eP*$q-dAs{Yxg6r7K{XQny$
zuFto@LFO(4%^5+U<VLY!PBK^}|FB>)Sed5)XcpljgHoLk-fuxHj8SUH?_S44lxbG9
zJKI-pb*K_qKtu(S2gtRf>s)s8GYm1?UB_H4W~>MU+x)5|cG!1KS%#edz|3m;E{rW(
zHP5AfqF$4;1`HMlWiEpJo`8_n3ptebs4-+P&5vh$xPEC(qss6$DZiJ`+_UTK*<E{>
z{9SxW<f!qP5!|rplk|+UH*C$TYSl5Zc^ACh-9oYsa9QV^s~GTV>c2>fya7M5?34IC
z_USn@Y8H*&bq_Q#>eJf#?uN2>W(X#Qq_{<|t4YTY4C)0)h!JTB;zW*>o{A?U4L9Q%
zU)jdvU$saGf+v?vi}5@fy-_0yn5=jnm2f0E2&zw-E~Fg=hlf<E)l;*ZP_$|Gv|3#`
zYn^VIT{F9BYUpcv11&8$4o7@L2y|6;8F6Fb2Cf?xcDZJ4i?UkHDQC`iK4EmsPHW5^
z3mdX?>Ug?1lIq^{(SK*ttO2@>I(LTn6bSvpsP7R+$>YxNqQTH=;lv*`zF^rhaOJ}K
zLg8x2=|1TuA#rhy{+UE=^I3QAhH0QIVnh&D4g=I9<!paF3a9T6M;y2Vv5p#HyCz+W
z9Zb;KMuu)rZY(SuaCvq{v^>^aZtQ#lmLMuH6=mKa`6A6GFzoqyz=wQQy5ulTUER#|
zy!K~LG!gF^DfU4T8sAd|+v|UM{GbZgFg^UuO{@x?IS=u}ohEMO_i2-5Qq}9lLWhvo
zml2(@mM1(XRJ15+V^Lj3DyzWG;1T8;1}`3(a!wJ`&S_br*Pl5<Rs+5nmM5@Wf3&JD
z-abo(bSyLXg4qAMn{1=2<Dg`4!#$z-w6{s8hH3-6ope$o=y4}2lDmsk$XIxCKp&%7
z+m9`)9Y1w%Jcv;l;}DX+qN9nzssIWG9YK{qCcNRrhuPP`!B54VD8qIF&JC0~#bUM^
zD5v~Ssnr^f%@&o=-P=<xsuI}*a~Y}iVe{S#k#8Nr3ewS;{)0>lmauWg8LWuA3PT4R
z%Ou0aQ-8r5yv_AYYTqxZf!>O~8v|`!D&hckpIez+#UIQV;ENyw6>6i31!s5?5tp$Z
z$}A=FWeSl(=H;fNnjn!teo=&pim{*#6N6^6qtEWb>>zcK@CaWj;x&&FAHrFa^yBTM
zaiTaGiCn@|5r2TcTzv&XNF@X8HznSY(EsaeXc1aBlAX;msTZicP|2Y-)UDHVd}l}J
zc`~0lP|@AHPs3(%%N|T=W+Etj^X9qU4fW4a^mnUe7`VPFh-NJG;A3zC^k)DDeiMhb
zfGs_}?v~O6Ro%@o3#dIlxEd8yC0kjI-nfY4(%c@2%0EW!r^b+8rOaxEpM;~Q)TLYJ
zz_gclI*F4VO&gh;W{{LS8Q%D@*$oNO)*^p`2kQ~kY}1kA%pZa+P~kWdWkDAn(i7D{
z7-~lC26|v6Y)pWt-4uw9G90Kw&lF+$<WCC*n^C51%!XSH7TnV3!cferSYZUj^#*B=
zejH+g7KVDWZk9mIOg^QmbsMeF969>`X$cb$Y<WU6f{vlcC~8FQIATPQ@nk^ya3w$c
zf_*x{c<So<pHH!y*{A9cd-F_v=BDQMDUUZEI~Fo=9CO+0qE>lw9q&?<F2e*I#H9}y
z=r%|NWQ=X7HCVM3M}`r^kxm9y`ff0{?$^+X+hk!m$Bu@r@*VrjX@-owE!{z~z;c*;
zuIB}HvrG@e-elNrW{lm!DgGKu09C?LQ>KEtkg{!S3#}LGF%oXQ&J&^W-jXP{HEdrN
zkMXpxUkm$~MHurDgHCl-utEN)3>>v|5`yYd(64H<P3fsm#EW*Uj$j0!#l<@o3uqDP
zk&74sIuCj1Ecz-xeDkOVEaT5$MsO5++A*Vfuy8`$Vh@B3av^`76&>@P55NDWbar{<
zW+zVUda{%O1VEKC0|C<gUI(|gCS39{lXe5x9_jugf?8068Nn#<7`M}%zV9r9$HsiO
z_%jT}*z$G;jnW~|#wdciUCzc(?6bw+6&?geW5V#>Y^GS8&Fl>qVxx}0LyRv9a)CXf
zQ{|%4{#gmHLkL@Xjl$XP`>cFQhnDv7p76bVNxn4*WyLdT4?<%gY+LFOHo-voglWQ^
zhS@S|C@XVnCbw$tDCDyDm(K>ku#7D%R*R7p9J9c{bTfnZB;-{G#|}Zb14B0n8u1al
zv@ikW|Dy&kLaT=0*yE~Af^(mAGQF4PZ!j2W;()8m<l&pQsHF#uMk6@-8jQ<xf&~me
zL>VFi7j>ZBXwnTqgJdd+aCJ#GP>7K=NJwYV%Tr8E_M_Y>(j5Vz91hyRtDRHIOF}cx
zuJpPS$_r0|M!@>HMWT#@2G6J_#>I*1(td#3!()-y@OBuY91&<2DQ~X=&s>rB4}tO@
zxId6eKX5;gzGR5<#y`MZGh+frbRWqtznsh<c}=q%=|}rtI~D~S3kJw`IT6|t2!s_s
zx12e)!fgx2n}^IO;=rq$vS<xHxj2!F7n&NFZzRdhY+$vNTin7jb9Ojd`VFkpBy|#C
zj-<f3f3R0I=<orJz=1?EL<}t3@UT#}S#57a!$7&-zN|qeCk=q8T&T-6G<-<I(3pc<
zVW6E}W6|gllwoEjR|Anc$IE;Z`znMLy`4f~XRlG<$w_Q?=6_7qI{(|j7u@_$Xct)u
z(10sYS6w(UQ3yHd<m5UqM!hD}1eyN&pad|8X(5T@h(zMSy5X!}>mO<hUGcROJBpl%
zq^`QKEq<*D4DPYnvu&G$@up2n0LY!1|8WJ-x0#=})mt~F`;_9S5*a*|C7f>5H%<#h
z#D#cKfBs1ktY*-T?z@NH+jo@4O}9|J@iH8gL9kui@~gN@JiAm7Rw38gn*sQg=v@a&
zG~@T$06r-CX$G7Q8&M@NjM5q;6@mgXfD+&X1m}%D8jT@F1dBdefGk2?2#Nzzr$N?8
z1O&&J26{eF%wo3mwVBOk6qE~5Wm2o}`23gxjXDHIC?5uYRjO6qqUar^rv5khL)Bv-
z6x8w#xn7ZR{e@UH3v}4JR4h6tE{x8ni-^>4tg$cCJyTVjQvZQqq|Nmujv9LEwArGf
zkoOta+1KTS?@_l!jXW8%C?v;J&R+`z7~5M0A~u-SVw$u<yrQhS5R1uRT{<wUt&f{E
zn2>UHz3mqIL?9R?YqwXVOR(Gjztk0JKp@y1JQ|HRcAGKbpbD8R6rCZUlVLh(=C%RQ
zI)Mm6Mg+^5Fyi9~@xFK)@*%L!I5GcYiq=SWmZq4LS@SNYG_7n(Nk5R+w4y1Mfrsej
zSLQyzeHK>xTwGP3+kJRu@$Q_7&zPwjXaU0G0bl%DsDoNYr8)2b`|kU<wJynY5sw~q
z>!JU*UkO<PA~C=<F)w-N3u?(>h=6pye9wj^tyU5M7Gky<O$1?N5B`YQ6F&^C)>#(3
z)7cy~iii+oV@AZmzyMr==CZ#1I_1ltj*5R%o~>cyUjsX4W#^Z2XnC$L%!;WbCXV3D
zHYMQ4XulF>JlgVz0qWliwad=_;O|b^IB{NfzN+%PbghM`sw4ojtxGS+=0%Y{o6vbB
zhNVLsBKWU^kCyXO#L-9%KZ&o7MB}9fOlgoE4ny)Ib&-fJ!rq~z)J`QRmP)G;LDo(e
z9QF{+pb;Rtg3tCc7y~B~lU}Ghw%Wtc%08^1+Zd0&S*O=wwxc8HFlu4G4hoFlb%mk<
zQDIHtKw-bR4qzla9D{fmu6*?UwtoKDzxt~Pmx84iY&KC?zzio;Zj#JKAe+}gyGY@|
z^|ZI=YKDh3xyd<iNJt<{Rjwuowvl)7GmQWf6V?SuIx=47DBofY=%Pt!#+T9)*5!ji
zgzlc6dwZY|&Sds!ofC3@w*on1&m*aFoJ0P!xY%I^7rk~JmU}(U4b$TpLFV9I&-i8^
zR;`MMDG}wko47vWPqjG>F5=ed-7}`$_};zFSFbz!wqE73W%Fo6Qx{j%uxr@S`v%Co
zWtu-1Z-Pc7b8A6H#(D;$$fpIu=%{6|>A}>_d`2-;F>6FN(u<^uisqJ*l9rZJaA0;W
zJ}TsHtf=S)0$QtyUbpq8$GNTI2zOPhfi7C2>Dy_*-@HwL$V8ZCGJ$Cd)BJd%xMVg`
zQcPTCRev5rY((wZ8fo>cdaKoJHi2GtCrFD2&zsSoZGU_ChqdbiCw*U%>Gw+ckV36K
zX7?io4GOXb92d<V`D&u0DQn*f^u%T7+C$q9kuP6;6uNdH^}oub_oHC)^?O$`G9B3^
zuW;(2w7h1ymnU;~;H)Y|e^ez3KeUYx(8*;4tf3!I1I}$Yddy^!`Vg)GSyhB2&|vVz
z4XsOh&Yh>???VVT-m6-D>JLR|XKwDw6+}-@5pAljZu*h*+}U4W2js=-4x8h_mAAr|
zzeH`^6!ASv<k}u?d!6+g+Txp|hmB3rMS46x2F>dsy1Pkvd$zE_#13=`Qr2t&Tkn%{
zSJ7W1^I-Z}L{+7e(CLTCioZ<o{vZT#A%I}mVe2#p<z~0EtsWxbMy#z3jJX$*<#Quh
zH4s%<c&hN9)uBjWbZx-!vZ4aq|9mN1voxN!3gTUa)`u@AzdT>x6!D0I^_StcNF(H)
zhBk5Q2MAuN{&^dM7tMvzKbe}P=Wz_}w?~<gK12U=sF#M(dZE`ko#-7-|JZCY&`2~k
zRw9*KL87k@0HH$;WCdzOt+*19v4;G^#9f@;Vo3r!uxl1Gnc9537AQs9q^}PNF{KI(
ztsN}Xg380q^+$YSo$a>bu|P0Nan_u^rmec`;OdJ15*w8H1o*Gwe#pfr!Rx3BdrLzj
zWZjmwQjP#ttJ*9tONt%C1a`P(|0X}>{vFoB*k{hreC!PU;#UL3nh;i6>5-0_gwth{
zbCze)I0-9u2?HVoU{01g*0s85hBTN#Q0&6encVN(r#%omLt}~epOvv}ksCE;4OQ*-
z?X;at%ln&!dk86y<_!GF5aW%&Z0@EH9QWhw7gx`Rw^}*3tEHl1xgniWYFCh8T!o}*
z_I0TW>g`>v_JF}%G|54gQ>HF>v365Rqdv#zk$s2rr_JU6_+D+8U*8yGCiZE<da=QF
z@1%)17rVF_8e<$glYkM9T|ss+#kGyoN5XvWIl6J3z!?^D+(HBAI4g%EX=??~K2$FW
z2Wc=}-`R5}b>H2r@{~}nQr96Rz0Nseqb}KE6BJ?QHi6bZpu-Z@9XPehGSi=fMM?bk
zczcZcj>Z({N3cZ$>^aZjXFx9={x|z@wDA)JA6TnNvz}SfE%)*!>1_ZW^&BMU+fw->
zVA(kU`x@B1KZ<`uney--b2N&t=tnA2S+k;zVB>)8)hvJQt@k5Ch-Sb{t!bkl+4fyM
zmbVv5D}oqu@Y>i*By#E5qFr7V$i}(M%zsd;jV6{KZf$r^toa7PWy@j9<-|zHw1&5h
z=H*8FOAu-tM8T+pjJNl9CdM=}dqyCW;8U=s5+x&63$cmp79zPO_RrPS%+v=Ppx%F9
z?GICk!!nqH08;2#PC}6NU+H7ksDyxvh2xQ{&z<`*?Nb&+G$m{In)&wHJ*k#G+tiej
zf>uCmgzp51C>PD>Mn6qwa-1ioa&ib@sA6NpJf-+NTXOQj!uk+YQIN(A$QB*--*lhG
zHLn9gr!F~^X|Ri+8y@;_O^<OH@8L{1p;f{G2aGY#Db+FPAx=`T5dlGqLY4CjF=$M$
zmfSfp28mhXztDvI-46f2Fwz^-TB9%-%mSvZzxfZd8HbE!{gUdTT_yABf>AgU=*6_T
z0JM`#bf{Ex(lY6qu;m1UXzX8grz&#8(drr+leH`F(8wX<A&7+;yj-@qV&m1|>QblL
zsMDc(7}d3<3hE@arKS7QVArRezr8)C-Om%bw2nY?TGS=u3Fu}bk@#`6;yl;NCuSoM
zb=Jlgz=1Dl;gON2If-eHDodQ7ij)$HDPVAj4r3U$T1SuJTrA8=wZ4d6+=Q(xXRU-J
zHi0L`r~l8?Pa+pLZoE;cVF^PpA?%8lf&BwjUv1AOyZudkFkw4>y!TCu#`9aaNles+
zE<dkQRfd0j?GAMA`W`6|@R&t?Cpl&wTN~*^VBeiKBwPaT1h==tINaWj({N`CZT82+
zb!WTPsnZcN+<Lux24Qs0st|al?U<mV0*c<m3E@yu^t^c>xcqHVGHKLysdRgkR2EfX
zmXVnTsVopsO)`3|Y@KW$^w~4C=V$?2;IHEnIg604IUUYb_D(V}pE?*5Pazq)S5IZ<
z*JB6<GOuy>utdfllMtCh0`YQ@)4+WXDgL+j#*OKDocySGnZXm8<ZB{D8N=`RWkzC5
zKk3__X+1rJv!Eu_M6&q8h4*)Nb^Gke38Iq1>OB|z&mo)l6hmK<5ah!kz{B;PvX~=T
z?f)1A>^+WE$vB~&v_sXr?QgY)k$9eg#55Q4!@Q<eCj*O}t?iv^B21~M&0uxO<Q|&n
z^NGEK)DSGeCvgNx-{7!X3<`qUZp#5o0tcVhg6HOju^z=x<1maN0h_b=rLf+ZxE47>
z@uoWw^zMFh4rCiJ)u%?B7CkNySgpaWFmQ(2EkPH#wxSZZdhJhN&fR(W>aZdc?Wvg>
z{YiB+Gj&NcqDU37c9KiA$Z#rCedjSL_PDzkw}WrR>QAZpo4+@YhWq*=?d<@BIhDg4
zb*V0j+yqmiF($~hK<!jIsnj$dVwiP_w+TQoR!iOeN06@rNqUE#If-Jv^8*EXAnHZo
z-W3>e;X-940W=LERz&3A;Jo<&+;;X7#1Gq~dHAodIddW=BMwH-Z!|wdCJ_)Q^{b)w
zp|3XVSV=ubEp4BxnH9BV?_2bJ=?t?k%*ISGJvh#G>J&J-20{}Q*3H>q<ox{l`gc4B
z=fuRkISs%j)ZCDv*B?5Bqf0PqsCgpV&~S1IBeW0*jhdHPk=<)sGG}eb)ay=kGpJDS
zHbx&)q{qf?sU!?J0CFYDvV_6DzQ1q4Qz8P5jHidG_jsJ|i8YN(PZh{%rlxZa`!|wQ
z10@1vqv_WZTzVp4kbvBX8zKz2WAr&POd*{S1bYs?(qs!86&_WHk2MdO^+{$O{ammX
zCaf#~H?CLzR0<=XLf%UE%9+ti`5d1x6o)%5Q2A&HLUGvl;JIxh-7mH>OsZ3b{ZFO2
zKA8`_Fq9cPwu?r3yJ@NKmcVp@Fwo%DdNTHPY)KLHz_6Y>LPC-HpOZJ3HY6)}Wr-S1
z+=dN8CbA?cY#R^KOSK5CPcQv5htj2;r*c0C4vNyfEkfRRKmM%$dHH)a;dO%n(5WCl
zyym^-KNbA^<99sPZ%}ZP`GV~SAHN%3fa0THlT-UxMEh~+UiW>ecwJKqZ3%6R)&ruX
zEuV7O{r#-tWY@pldkhOLq3UPwz1+xtS=2VEY#Uo9Wp5Yl_9)=NM5{4YFQUzi_YI@N
zwJ)%J7#f$z{$Op?mMu}*2kZx9<Wu?4^1uS4*AtH_E2p2O30rzAgtWh|zf&4$%=dUU
z&>kKK2OgvK+6NBa^I-{!&AtM;CLeax3eXr21p85`-TU?ds`Ue|L(u7pwl-drUU#g!
zfs-7IK<zV*wD)?G=KFi+cFk&9pupDTqteX5p=H)20%}*K6&(R*`|{(2en0uehMer#
z{_0aPVfYtE=kz{awkLD};?z~p7`x?{ok|ywx`Dvhqd4m5%nSmM3*^PnGPafIalv8H
zo*tsOgbh!?jN1hEvSq~O90+Acm|PoxjLaWWukg8tu7o}m+>6ajsHk|Y62>TS1YF;}
zj*?g**_?((2C#s#h&gbvniZyn;RzdK0)~?4kP^Vwa|z8MTCi71zb|<}AdK5f*!#Pj
zCU08`-{AdSbaP~|upB37U-}ZON}`}@Q|{hAO&;xqRo5YC5;Qs?A`bYJo{wno<Gi=z
z?R#qS6lKexB$d{0q%!yW?}eS8*{HVA5u9C6a1{ZUeS9Z8=O=%uJc^aMhyRREt{Q#G
z&$xQ5s5Bg|_@+O^2IBcMVLs+D;JYc^+no}DMfyub-cc2ut0R4I4;=G0cSx4T(Zn=~
zQUkWWfhMBIFKMxOClh$6-{OQNV!H3F16=@J9*c<NX6nC#Kgx`<kAuG`d08B=Qx57w
zM2OYF6@Eu(-;pU~x(Dtx50&c;I0giG4dGLFO@!<nE%BX@n^{|c05c3rJWIsXD2NZi
z=Gv$X<1-@zvlGG)ES(6ngxS)Ogo^H4857gl23_PqYu53UBRp>VT@0L_t$9YE)qi2H
zffJ;A@2JSw+afxNQbf#Tg&L03@YOtZWF$|c*6<>5Q}Z>EK^mm#OMuM+ULUk{>2MD_
zO9BzbNiJ{gKA=G8wQS<Vo8i-_O~P!{yVqWz#I~xfmnDOENmgLbPJ)g8o3jb@{#NRW
zxx>TP?ot8DA#RxrYR=)6yiKJ1PhW<fAqTc>(&schbkNE8AcR*y@dHzAkBDAgvUymr
z_l*ROpM8T=?)sHP&7l->;cM%jgMB>IhHSLiP+-Yp*}g{9*q^NF`9eIAyH=nK-X>yK
zuHF&0`YNQV%wNQVC&T{P7_fIC1E(dWNi}Qoc~OY;fqSo1y4U?cibS>Snhr{XW}o|)
z`g3zf=N#$jAuN_wxu8EYvtJ-@wO9aK`5~3RskXblg2g`U%GFphqXc|^)ec16_>l^B
z>fJKTyb{l}GaGbzz1iJ&TPVuT7E@N3ZQHz~{1YF0y$mSk88THRve+=gL91#_w1le)
z2d_a<k-k3o8uVOGV-J3q(I^QZ75BT3T~I*u^jLE~{NO{dg4O7n9c^vzR6c$)!RiC?
za`UYZKOz#>tTD&rWaohXjlchU(%znw5)z;|4HI6bHBC+H^$tY*9M7QtWl*jTY|e@@
znI1kiRGGL^VmIyD6@FpkBK~6~%Ed<5jD!CwlgT7Or-dJWHpVdjJc`q3M~)CnmiYT#
z7QGl`BbawVJ}_=LM1E!@v(gbGygD^iy4A14G*%&c)Szi{sYSG2wxJJ=aTqe~$eLC-
z5WdjS=D%`WTr2`Rd^keUc96APdmOj|=rwirungYO>}~YaJ?vKwix3*M=Wp49n-s0x
zYJmPd+3?YGCsfk5&|7sC7W1)<FUT@P&KWti{<p(V9z9A74W(rpg~Nf18&3WZLQf(j
zKca_dX_@&db}c@;0{m`jRpZdT^>WDmW_iFNhRTFm@6;lK!1?Vb5Stj|1@W=QP6bz)
zvA5KIUaqdk2YD_(Z@g}Lr3F|`S93Fd*0KYU3s|0cYE>_-cKC7oi866{;%AS4U?IGn
zGvE3cs^dAtnX@r(nwah`!p#ChI=Ee~=$Kc{5%Ik}G^Z!?6tn#^r#TjdI#9-t!)yS_
zC_ienOhA=CXa^!fM*9?^LZ_*Rn;jl5o*t94ac@9hY8Byyqhu_OXRxA0C~QeGd5oW|
zQgs<`6~K~N-|TW}as#Ng&7d(Zly>9xP#%6;t_yu?#W|-n;GjnO5`%aX!~yZ(*NB_d
z<`CVx^aWA9C9%G<($^RH_3<txph~n7B5=b;#g+*+J56U}&6Y1h3}8ays5UTR51#}6
z*5IwbJsXN|u9JwpJ5M*@d<^WlC4?`wen}l|Wfs)=CZ_;_tfl_@3}sL@lHw_ooNY4u
zEVKZ+;RJ9DOUPs!l`|JHRtGh|qgqhQb5Nz&s;>fP{?VOH#5auiGxq<^LQNm01dyK3
zX3YUM<o@S^fIs%H%uD`FD;T8^-*>Cw%x+$x8kZ1aSv*g}YVpx#48<H6I=3u;DXn)K
z0<wM5ut;?~$)4U%SCU*mvIw7^=112c=-Q*^We4DSwa1vuV}&bVvkcE52QVB$S7k9f
z273d_DBgr$nd;HeiL3E1qcatd9=6d_STl#}`hWI)5IUah^vOM1ell!(Z5SnYb_-!;
zirQF!rwN!*6%SdUR^;x*eMnq$HGxpGA9ppWiG&HxTdzZl6zT;CPqje|rC2YXO<Akv
zqr9W9_RIZCO0+gIj~O&~%ztX-xdFHHTLyQeW;vUEdZHqE8{7~!ggV%fEDjO9*+hq1
zal(otqE21lqheRj>mWIIP@E5kW;ExQhOw=7MJT$NFDDA5#Yu>=Xh?|zQTJsqr3Tu{
zTAIN8=txm95b!(1ebBiW<P+Ot$>I)}>~i2LP(`BFxcSMK{l9j|AN-4c`}9<0+Z0rP
zq&t7Cv$NxLM?Rzw5p$reK2Ms;^sDC1-M*cNcUH~k+Vd7K0uR(W&&$q_6W4WmXS+4w
zqg|X{wKHb}XT!MF?as*=;0*L~dy|QKeb2aT{Jhk8*@z5K30SoY0p*NVp^(-viB2l5
zMh7ySL(CWVZ*p4jX?a?5{(Fu<qZDi4wT8g0VPY=6(*sBN5(mEeQ!c^~Z4e64)Q|xI
zs=_K-&*75C565@yGKTY$#rOa`oVSr&9RfZ~UL}T=o~pMYK#rjBGWjDXKg=dLC$C?`
zUzc3vuVVn|V9efJ8k-j_fc|kJ>hmH{E$<~4e6@x}a&O##VIDQjS`jT+(DS`;6va@j
zo=y>Tvsz|{dt(M1b1!bu#?dG$eY6*N?S}fT2gP8=RLlu{xpAB&yYS|DV4d;6dohG(
zP0-f;e9pVi-O|F61o?R8<-}Ul4Mw~8*#5A|bU47gE3=zG96XJphhe}oJzDy(N~JQ=
zCe>aMBjqjC4oofn=0H!i;+M97Lr<=P=o+Vq)tfHA-gxX-gW?qif;Jv-ik%vHuE?tV
zoKA+5z!84Fkbut<uk_6qWrkcJZ2$)tQtb*u?E4{E8apMZ%W8jkBon|3{4&3chMGHl
z$Lws-!Z356w%cuZp$b~-J{_b+L2D?d5C{-Y^Bm$Zp1+kQ%)8<3cRIlZQ9tBZU}|)4
zC{znKxc5a*NbbSXRm#ZI($i1WCy=Ah{<^Gm)u0=)5%R`L9&rE`B$k319rP3T5xR&3
zRQFwGikQp=D8~Bz+QkPfdF%!hLH|h@r+&Kg$^vA;m7P!39X$T*3g=(h^-SIA&t>$L
z{A>WflT40<5z~?}bZnxQFm(}K-9&dQ(Ylur4a$E#K4W5pAawev*^v+dJr1K5G?Fa>
zyR+TjO7^?A=mO3xXggXG8rVi}CA*3V8up?eQ&wd&eV}3Svcr`pHP!ypsl2$8mDQX^
z!APKyX>$f|=bIu-1mzU$r(zD_D2Nl{GP+2QXGjTqyQt9qH)xYRUwr_k3!c#FPh#lw
zm~ZKfpxBsfAOMmbg#W5=)T;1sUiigIIvV!gIyUFiK`v+aryOrHW+F((+d>>_YxAJr
zsFU8r#&{|kU*xEP3&+;a&$CO2?1JUu4F;2O<M{FmGDM-5j>VOV-n~p#=2BzHQV$dJ
zt!5Cx_!haAgok`=^T-)DHp6rX6S@$)S8wj`kid}v89_Q&s1%Qk_N;BvHtCUg%r<Gm
zz=4F7bfJ}=Zxh)V2K#Czc(naoi&Rri``_84JkkpU#*{4={HMy+NG)6dfJ#ngK${oW
zc|*!T3q~Nz8pUn0E<n02_1SWg^s7EOnjdO1N#K9`SBcvwf`F6c-$a=x(`M{NAOX>*
zkaz!&i{ufDW=F^iQm#9l*9plQ(X+54m{>&9VwU|$DM=+qm1Fo%E@ib^KWqbsAiVo-
zvkLvzkW@2CU%h)2V}$XjEDa@U15Dsg>5&N1WSUw@kPI$+a7h!x$glwcaUq%*FZqh7
zzk;?P8x+sNDKJYJL7UD}RL-FX=8>J8v(A3<97Qe_fEBI<X~FM~`__#-4h4I~QXtkf
zV+wlpp@Y~dQ+Uy@^Ba<Z8>@)ioRpWk$#rND2G^*>AqX5?Q=1@c6YLXzaCI%_5Tv=R
z)<k|{m?x1*Gj2gG$o|gGGK(Xl(p^?Y#0npbE~=s+w#u<Vq{b1|BM*(#;h>FK;T)#8
zh)Ml3p0kCk7q+$n7mmOf)7W2!W(k8aiGy%ax^}S_Z<^jTSo2Q0%Ivks^y+s25qrq7
z09DVKlOF{6)kjFpfevE3r+4n`8gC~}XJSvHSAYW_#%V-fh&eEiVbJ&PEQAkeX(K9!
z@ez-=Xy?&RFnKvovTYyS&jiz@Pi?HAb{)GYQQjz5&8mssP%f(g3yT8$laF(rLCuxR
zbGS_cZFJwe6a_VYHSLUIe@i<Z9c}E*S$mw~$NjDif&^iqGS&smEW?se7*{P~y~>Fe
zwx_C=J$!H!WQT9f%j3G${l|kOwCxR&FTL?Ns}gqxM5Q0ldZM-s5{x*6MWqp@zbXjh
z+vKR&hY&JYxTte-m<xqCa4Mh%a%)~X=}+S%PQFxQ`5lo+%XwboQ2+-p;v-{jLLC<T
z+q-ZT$BhpSc$5EeOFCbdoPM(k+2Rwtt%^$5kRkSRDNlJ3DT>i<6g5V!|3Ii%pMDbn
z{srLM9UrfX$FR8jHPuDF1dEXvu14qiy;*U1#ay=F;$H0u)Plk&ih}1xn@l6L%LM{B
zgh(VyF2`_pkjWw}wUf0!pp9mnTEKyrF^wk7)qP4{Z63l*bbAQABqpW=@1oIq<N<mR
z({-~W-m=!fd17;>P-_c|LN}`MPT_U3!yo|^m;dd>N<XM%Mw#@2x#te@`j{+OG|V%8
z<X%bTY)+)Od9U1rQOTAC3A(3Cbf8MtFfy!yjs53moxT&4A!31rniJlNEGd11Or7Qd
z4K@pE;p}k$XKM@{^C*hJAx&ia7a8a{9dk6V$?_q5aJ*mCV#&F9x{)rP9oVn(m#&L*
zbSy5ojlfg=rjDcI(u5WtqE-Q8%t3rOZv4w3SP-Z&%oohyS7~oSyfu3zmu#Y;^_MVe
z*>8hDv^=xTUv9`SsAV~9+(Km-o2ZyRn!rxkF%ZYlIvKtJu&tDhB}6dcj@6};k_b62
zYS(!MSOrLA&hR|xLao5N8}rZB0#+GmFHDEFzR`v{I+Kdzz~zvfdUmtfyWKp}xRp9x
zWagC(?rU1@Tqki=0f(liyXbyyb5&JUs=2Z(?|DdJI^p-50qp~y(dVLYzpX-192Y6l
zJWd!2pRDQ*fNi2vzum8}oBA*+zW;5vU_;Cf%mI28GJsO=;IQP2|J#f8a}M<9$Ze76
zTlmIZg1Am^6DQ$(L_ET2Gy}|&=p+vNeoR1}?gW(&Si5Xp0~4LDPG;Y8s7V`qb@$at
zDs}Sesfl1&YpY>Ju1GtIpdJldfC{lgT(VCoVU`VX6K=(I#KYt=IFUQ!0%I`7gt0aT
zSrlOr6HkG`Ip)*PXgKy3mmnZ2>9gTlWU`5)R^xq0R9~|?=i?<7RDm*l<h(Baf$3c6
z)5l1A>i#lFV6=K34XC~`r;lvHmqmwYhRmBTFg`Qdt^K1-g<0em9Q5qa5{iu3qlT2A
zXLTswKnv{rdK8GGXq}AE0Q?pj$=Bql`H_gQqPL|_gz_mDoKYI3<4?Ov(MMkAXAF*J
zVIhJ%xIX?1+q=)2y;JisJH#X-v9>SbY{|g_9HI1Urt}fVO{741Y^=go^>boO?f;{)
zMS#=G>qg`QPgeVXcJr8>0&BndQ`Gx64=l|O6#XvL9%N&r?Ca<(v40iW99~00zk$|S
z9sugVkifE>keE3Dr3d^J$b%*@7`G<Lwi%t;SP{nFZ4CWUPBZBjqNhiP$)x2L&QFG-
zn*7(k$Nrf47}EU<P!vPQ=UpnO3B^f#?E=(-dnZTY?3DaPv~tz2siu}i7{CJik!sL3
zdp<i@54ohIHqOxY?=D7rL5c|evu(2wGF>yuH+slkf{M@*yTK~gi}Z^b_*qiTP^XJ3
zJ<sPQC<`s-(hT9AIZf{6^z;w~1tb&^UD4<5sQ)0}k8D%f>!LND{e=ckMPbMbr~~*R
zBk9{<d;8$Kf%Hc()6FFNF6sYu^rt*EqxzrGuU9=3N0xfbN;2JZUh&k{zq)B{@(3F7
z*V6Maw(OS$chRLOV5hX`O!nF^ip+jo*_lPm69FY-PY2L@<h(xOmW->DR5&?-OR18{
zug1%ZnBS2Mm#zb=WW6G1ZSer>JO`!t)vFg&YjA~SxaR(kuIg(pgJo=z!U5c=+I4O5
zuEXC4yX`_mNSsH5WQG5Xj@>{kIIzvXD$i#*%5*bBUZuSO@kafXqB3?cIy?TnDh)1h
zlIoQA)!ry#qXnJ0+2O+&dr$nf8!VbN-Q5GZz$oZsH5e>m1~9;S7^DSsan-a3wTrHf
zU4xJhPd}?+M<@zKgNRuDU?E!e7hWLrzRKn+Vo_5~rWTWP4bybpX=<_WKUBeDRUDG_
zNWS~~V^2@DW!>qHl>sTH<-G8rG2k*@y)hm<Ju)$IrjnO-By1wfz3poW{C8BIVy@@M
zY=&9SaX>1Xkp^IU<(M1}iu~H{t1c?lb@h}h7&K$$*(u!}$QxL^S3H8H{>hcH4Z)CP
zSmiASVbZG5k=^syw?-pP<7q)SV|)-6rld*1`Ms23VGp+Yz}p{j5B9OY@`US@D_CDB
z;pk$ns@IesoV#3Css6v2uW=*|9u0M!1QtpJBmo942K1u(V~-FJsYjK{Lu^=5((x}S
zmy#9=g&YiyAMyF^MIn6n8B{%3h`je6hyXN+-g?31AvNeOS+?JvwqC<nGWOk_bA`x`
zEdOlim_pe5Y-Jn4I_HulU}<rGe?}vZ7sNN)U4X3@+idP%WF;{OPn)KZu0ekrx@Zoz
zQ-p`~yeI>H%VsspC=+HWO$L?f=affL7&}FJu#podCg}ui(K;LR&RCOo_JnpxIk&@>
zM{;_9^(*#Y{@r87Z-945_7R`tA}%=t%}D_Ug9@7~LzGa3hDZp={jAU`LU3qRHN{Fi
z!BzrJZr8X2?bsIv7sWl~9nuHn7&^||Ntkr$Ul~HOt9OawFZopqt@c&9-2pshB4{-^
zS)KFchN(}zNF-eVSad5^x+r5ba!!OXZR`*bea0{(Os54e-xFPL&$hM}JRV`py!6%l
zw56>A$~<)<R?AUx4|6saXaCb>YdU)L5V?H$p?lKsH}XlZqoa7)A8(ca<w8{FNtoEL
zSg6jKGmL%sKk3y2i&530;B46Ci#J=E7lT5=Y%b!mF~T@Ry5cmiUhhpSW~1t^*;T5F
zc3Lp66<13rduf9q>~e&Jq4X{xX^$eLMlO0FD7z%Vem`T37=l>F;?O<BUt@^L%waQk
z$@s$dL%M=~NVt*CK&hVj&&R`LY(qef>a}@N)2Ln?sN0h*b|Dv@pac`Oz{?wu0lNZO
zUnt7n7?cKQs0U;8=*tSybLSJXvfoTR<^fH-oV;WwatJ5!$qBjO5#+D-EdT%`>}L`~
z*FJ-=YXL6o3nSPrVuB4?qFpAq+J}|()tO8C`i9Y__V(7vU%99F+4P7v>pI#MgQB(=
z2Y_hyOX<5W7kc0O=soYb3iVmQ0XdQ!z=w9RM#P6-F<#LJ5}oI`MQH{uZ4rl+My3TM
z7*6wXt%ax`z*=}2;S4hkc#8UJT71o13QRuzDUEMmTx7L9Wi9XdkajHJ{cU>2onXHV
zf&SX};%Mqn7#dkr1+{|-43<CLvBuAENXEZ6G=8?Ozp`K06koG7?wHP+dn$o0hZUXT
zP4y;2#c{E$&2M)WdIrnb?^e%zTP|o^;?4}!gp37pjnnHgBockI-f`yNbma7s=}S2(
z%y$WM5)Xj#2Vlsd0rBKvtKHfg(}vOse2995)mgG5Y1V|%o}`@Fu0HweWVTg^CI5O|
zFJ+XDFa&b%*F=$YAdonjHU%5{K|aP`N~cBCW{ObtkGXWN`d`xCv5)6%xoiF)(ny;r
zxns6F39jtFU||e!l416M>Csq~hTaD<VpZ#Y!qs*`2yjPFYG$yY3@)@Fn3)PCArN<w
z=4biXi{~5^(_yq`J9U0XqR2A4c6CBydBu`-D--%xC9LGf^%Yw;CV<JWFSw105+@g7
zby-rkwl9+}A(hd!!py!~Cunw}SRKSHO7k4rl<j{Ef>Te(#aZOPe>9l?_}_HYVp+b#
zFe4z~K|rg&IxnHC@d;j7@u`SdfPR67G{*CH6r=PPrwNB{JI{4N*BwukcfNa0T|jwS
zb9pfk@-eRP9OYs$Lh#zKG&`E$bL~DAH|VPezy#Z-dL);m$oJzlZFZ1NqtBp9xNc0;
z5^0-4Q!rIK!DTnbI~&Y)N9Q~MK6Zwd#sU7Bo@Z|0#!4Iqv`1&-F$QC~MyZjj;2dgD
zJ?ODL{)+B1ZP-w|y3SN?sw;r5x+J)I!0P&%E_3fZzw67`3$q$PiNdH;wy>^3;fgkz
z@lp*+yzU6y!F&am!+7IkuM%BtaeN!haSB+a4#-q3i12+0Ea^R;iy3?L^P=D4-Un(J
zg?|QN3C$`W4Pl6YT&?M%&fwOkI(6zRpOs9%I(GhtNisy>^0%&HqO7_wP{RrOas7Ui
zba3fsf46^j)Wjzk(iR!GMQJUFgh;$HfpB05*Izp(5Blj$3KhjjDm|DbhvY0*tt4UG
zS>Pu6YF(wFF=29V0dN6PJTMgZUSkQs0X+*ExZxSQFZ|<LeB?k=QA=wOR@nle&G)tl
z{Q~NnF?=rUa$kT`sRG!UW?Z!^QB`TTPXT!XOWq}rhoq#muh|q9#mi6ANM|%tlH28i
zUC9`!ARx`o3X>~iK5tLI4!oZ1@+;c9^B@(|F>iew>V9miXzSN-XckfL4N@j+9)F-2
zm&+`iL2A(TQvVFJhhHoXRm{4`2ulK_qc?3E9^SU858bk&uQ%PvHiV?v_v@XroKW@T
zR~^Z75v)3Ntf_XEFq=U{x29v;8|3BdL3h0`4+u`U3J#KuhaOy`P#k-bFo$TLHRnP*
zoen;B&5LSmyL(zeLWmWRX6$GQtsV}r=T<nLyu-!d;2?e1bnC0Sf=Bg7hq7JXcOt-t
zMX8TSNbC{$nxhOp807S(_Ox0sOa16cQVTEFZHHcdq{)dIIX>fix4X#E{){pfhP;El
zDc1{RzAs;vWY1AO34*tW2Ua5N`UWE7;5~Z+mf98|BK;=J`j9=OeiuCRDSLkK)k8-s
z#!C?NL1Ay_wrUF<3^NrEk_~Y%P*4wNz$KMR1*!DAs6clas;~c=Sp^}a6k4Wwrh9^F
zL4S3UVp2J7apvKHd47%5{6=zK$?VL<99V-eviK=ujJn;he`Dm*rQY7i*gmHPVI)h)
zdu^&jsYv}E%PHq_UHzVu|G;}5&bIHyWycmoUeC<+L>7#f;iAmDy6``C?YWWou>I36
z<dS6RSDwX%*oIrixf{wBI7Oa9mIKfh)G_JMs5b{yEP5iO-xl2b&lwbyc!x>{L|&c%
zD<RqxLPB2bq^?z<rK6u;3XH<FmDEAkSWdb_;vX;=UOII<xBYIY8S`aW<N&gtOvC`P
zuh+2Zl`oj!U{%RxG<@YNqNS-HRpQD$;d=2am5z#;38sgXj!6el7U@T<_&5f9W$yvr
z+}7Rw^{EhK!|B*c=4R3E(*@D1*Em<NzOk*Pup^rp;C8;T3Pzw0b|I2dv=dFGsAsjm
zIXS_j5zSsWw|(J?`LXNVI;JXo$??Ng%)@S?r<Xgcn99=`ow~g8B^Z9jdf)CD0$WfE
zAL^y$zzqffh=Ib=53C<CKU}?r^@w=;ZMP$*q?iEUKtia3kDfW6eZ;h$7DAs5b2o1}
z`!0GnYB`U^{2Zcv?w4PW45Kz$Sk+zs1~OjA^$P;|Ku~B5R}Ud~?82rDuo|%;RtAD0
z>-a{(`0n&eOchSxIS*xLLjKS+g@fQ?%LcLW6pLv0iCB;o<HQq!vZ^34Y9Rx!hb*ft
z(1es1cOEIZ+SA_ZyE7fbp|h#ejdhl4Y;wHr_)_-#$KU&-E5P9gfZM!eD2DK`*QcJa
zW$~pbFXEJ&hs(?VoMckGW)_V5dS@O7TNgNTwz_7ZZID62@wp?<HAEj?=!8i5AQ4bc
zl%d$Uj%a%h>y?9UfsJ{zqhDfA_pS$dM&7E&rzNu?Pd$x;FlP)>YV3O##H2Rj{wDM1
zl}vKFz1q39xO*0H6dXC2(d+X?WYR>Zk)Y$IRwkefi-3pE#qo*xZ($xA;<4!_do0!o
zhMq?Tg=4I%V5phsQxNOFUK2Jh^%$3U04n&z{G`KW{QpB`IDTv+vgwijc|dMaO!9r-
zIqk1v%FafgJ79{GYwdI5zD_aUxbnc(ts}mhmk*syvl+Bz+J6yOHe_>{$BHTtq2hdP
zl)<F&nr8d7JNpR3LE#UjTP)TS?T5frCWxNzLw%G}5a2i;5T~bjK;js3Dp{;Ge5w{m
z*cZhv8)tmfn`QjNqeiaMh4%$@9NU|{jo2RdTS-i&tQ~?1$;D9xhaCw1NyTv&X^B41
zU{^XXByfaF*cq7O)ESgYgCcmCLqHr7OM(K7dXw6QhI^VLy3E(htBW-B*r_&e25vqa
zY4oK_8Q}0TWL$aj+O?|Zb}Wx7Ci*sA$*9RS8P5SC()U6xx!x$^!W<fPab;{7)cfV#
z>s;+Cb;HFg)8MZ!r6$^WVZ89=I}0H8nCJ5rL(8HsS0&|PMnrhBrTO{6&;j$B>4vLo
z5L);}&o4s4i8<dT91D*}@l}@+zMJ#AggXA@0gYiM%My`*iGATGCXi}W!qkmWG3$kf
z6kg@s;+%-6=A_zW055-Sq$&Puq*XRUdt$s#X}2McE|ZHfqCScg+_A{x>x@fvyfzn|
zq_~QR;kXAAQPTTDjd-OblMzc2+Zn0xaO3WOA9#}EXv=wRerjB^ZolbC?`RzCq4^u-
zdrse&S`VkXWmdUk5SoHqtwL0Zx4vbo!qI<QfrMB98-6|D+goYp?1e)CB~iADWfgUb
z$;pHjzm8jp<TCvVI4GAD563fu4e|*%q~v$O^;LZ$L_vO0UFaWs`A7}wB2;JQpSc?f
z;4sAEK>vY~nh=}E5=1Nr#>C(PdIdMc;lSND6bdGz$4<c*L~Z?yo63C(agPMXle^Q@
z^sC38vmh%G=S`w>EYEgbsYB}|G2^@_3@0(w%oW$8^;dR2HLUd}GCUkSr~zs-YPO)O
zxUHn*^LtclbjTS(+n&04c}Z#8CUZKPlDI_WE*IhgQo1ZQ+-7n0nfD`hGqWcnA>3xe
znd~nduTa}?oPA=O32fO49+)1Sn0U6k8@WRm4CiSh<>l)B$7;yAv%?P_w5RoeCu@yl
zHU97<j$6O@E+)9Bm6n%FyksvPlTW&zJq+)T1Hd3IJl>?pi3zZL6g)AH4ZzqofTYSn
zG)P!Gr@M8N0D4PF$){Dro5?Qk=+Ce=geAFhTl~7WUVR{mkBE?i|9TUW&j-~bja#^R
z4gney{N)HvTYg1nocnTyt*i9Eu|7!jrBn8vY3SYAgdh2rD(sET{=|`!0ZcBl(d*L=
z#vqD@uV?RA-`GG{A;>f;n)CG2F;VzqJh+~rm3J)kOA=;m$Tcc_x2h|=9O4pLOWCS<
z=-&u1hv2#9UoC{Y))O2$cMU+?fYn;q*l5$r_K&Rd7a`ja1c~w>9|Hb%ZfbEq@w<(t
z+XJY_iIQR~Sko1k5U=`llZNGkrh%;`u@<mg%JJ*wzWP8M9}ywj|MkWtpRXu9Z!$;0
z;DY&~;?LJu`J<rviaec+@a(X|;dw%V%(p94y4p=!97%o_djn|v+ces3J`JtDd}%=6
z_#{yN7)9&a_K|pNInmg7>JRyK-r~xkX`_|aOA8!bI%4!U&>tvW96quclyb!<q~O@-
zn3XFZsc|PR4Rq~J5C;x@lfNmkiaBy_<L;%V7*g7X%n-YFfx4)7^^yfY(MT>Un-aNl
zj&#vU2H$%jr=Y|xvR(Uu8aoqyJt7V$bRdo}+x@JdxWAyQ#>@Ll%KN9MuO_Cu`u?|E
zd9<c+bNVSN);wT3dNLTPWh1g{<|}QpZXQ(_vQi?FQYul3%rrPsr7HE!gnY#m{e*h7
z&-M=ktx{_K4sc8G*j-YCNu6jIQp4Ef*<)$`c}s5JC_~h?x#qX*w?h}TjrR8S<!<?z
z-uibpSkKrE(I<5Dx2)w%P&#xZh-#pjMo~)|ee!VQ;z_l)Xh?KBNCDyk2rT_x4v+r(
zkzy9fYjwu`@(#cLL}qkGK34fOy?XdR>+(@I3jZMqDoyHa(yZKBK4-YnhNQ8+dH^zL
z!)jBX;O>hLSWTJM*>CADK9z6v7G_i?m_KB_8BYQ#B<@`KG4iqf1SO5oywbZZuU<U;
z@G)Iwdsh16htuMEo-}H^#Bj``#7K&MA-cW^uQbBp-*gebbc7hd7rSSCfi%QfzL}R^
z4u`W!%OkEjRI|uzv=?n`=aO}FrzA=8ckr%kjENPsU8#sr!-1VNH!#X^tz2G~35Q>a
z0cgV@F&!PT;!I2+53bn1#!0{VX$>C@;)be$ArL%`A$PJf8Af3d%iCo#e<NY`jkG08
z&QDcV_V)v+a51CRtl*M<rDlAXH_ZDf5lKaT>LPo8)o3n)79701a&9>l#D%bc?a_S^
z6t~{Oajvb5pe}~J!7yE{`OCR!%|3oUokh`+>O@O%Tb|cVh2pl?!^Wp!j1MidVnM^q
zL3BxEI^r<XdT9LM`~S!I7^q)rVX5VIH&-NAv(9w(k`SbHJr8`_=xD*7U$4MG8N%@|
zoQ%Cq#;AGSt;!BsZ&WWKwdqEHfKIw`Qmy5X$J0b<V)Ih0gTS13k5e(B&?@rW%;WNf
zY3{o%Eoz$x4a*Q^b$k}2xcQgJN;-1Hrr%LML17fsX#JWdQSQGxfr@u^TEm50;)>Pe
z*zL;0fWRjVHSc*aN8|4=W_b;tU$gwmq{E;h$<&92aoim`8QJWo3qH7q6#rw3Tmfry
zn2k#poqly+Vb6()&?=-KxbGht;>@H@n?8^#PUOv@?TYVT?Qt#{7#tUADU>hH7X?}o
zFj^$DJ}#Z1y%Xr8<FHYYO&`K5ME2Ko6h_TL^ee(Oi3<Jkx2P*ggi%Qx!h=h3!8pHW
zN*t$vhfw;``!ZI2fmk{U$yBB4?!sZz3cFkt9K3|?!>$rfPF1*{LNC{xykim7e=nvk
z`26a~GEf;u(N1aCN&BeKjGC1$4u&Lp4VNY*i||!UvMQXC+;#VTR$4(QV$xg6gxqRI
zfaTrj0DHO|UAwH9d*;E?4w=^#!3mw7AVz>6MNnjt5p<89P4WT$hIXiJgf;;6LIbps
z^W|O0Mt1EwFU>c=?Xg+fR2SI0w<IoTy{ig(4HQQ9zsKZ1+E=Hl4(J}#;5(YKi1c{E
z(;iQcnqm*n;_!6rt@(J19VZASfhKQD?(FL9u{m!8&m{<sqBy!_N!54XU3;y=akc!`
zSI_rU4nl~f@jrHLiex_=ei|38tS@upy^Z-T*()s;VOz3iFLqza-Z@)i$M*dTqVH##
z#x|Y&2j28>cFxTk3-;Ubf=v5R*60?V-!htI6IX8Pytt3qxNe5w_#3h*{B`9uj#`H6
z>BsV{#44Vh<)NB|Ji{%(Qc+}&Em;u3^V51<fEYJJqELb(Y>j=PA6B<n;0mHMYMgIH
zRzA)993xzmd-BPpJ19T^nNbyE9_sZnl$ntM&IbasRn(9ZxjNkoo*dIxBNrj)n0rG1
zA;lA;X`j+Q3LX3Oh^Jpbg0g+Chb*gieLGsx<rXdr!%<=rUF$aG*=(Yme*KM%Yf<_P
zLl4_Unls-mNERUuIj8E5j&F`TQf-CPNOe;jspL^)?~8+i1;zpyq}joLk8fzRF&2oV
zE)5EyrwPb)fJ8cj07xr=P}G}~Ye{Wf(7u97`lgyyA>0A>>n+c3Rk7+2_|(B*9><ED
zOhSeys>^KLUsMLRXv<rn<j>n%!JP|kK|%oe{-|1j$zcQ2ROt*M63t2d8Xr8ACu(9j
z8blpDccdQpA-&TIwa_dkB;-rM)TZ9)eT*iD3XuhWU=X_8z%*6XtH|IK<*R<GiNv9U
zt83%Uh1i4bFjtni!w4!~MpGAuGmd!2JF22X@lvVz!>j!FhtVwwj@ZiP_dUr5kDeDU
zcNY1!zZ&xz5zS0&r~U^3%`Td|1MFgGk=TIfILgX~NVi!2{ExYo(b>^aK@P0_DIVOq
zbM)&~RYXB<XJ?1}X&bedB?-D6vK(rE<;pEUd!n<oHRdgj8A3bft=2RfIG}xm!GEp5
ze=^+vVb#yHaA+Ux1(D5@9L|~VfcW8Q8ppC-BU(*a8Be9Gl&x?%=rK2siosaXud;w!
z<i+toQZp)1HI*t#;8RP~tj;5E$Fl^vMwDb)5=zo1+jxrllf=m=IWMV_mk_W-l(!|B
zlNM_GrvMwp*O{4(!2{{Aq8ELDMjN0<UXlhpSX<p2s%7cne!59aH+{klS-mw!P4ub4
zdJ9WG?4?18B#lXgnzgdFNzq?Zq^ipF`y3;f@iHB|!-N{J2e(*_p7t1ti&C*F6X7KI
zeA&@C`hRu3C1yDX6;I_XZ!JO;z8i^sF>uJ1(CZ0s#?JWWk1E81G-l3s{S8$5Ld>#U
zC8~H5W`{ALd4jdW!>mxG&984T7@oC#8J`{f)&GXF&gd~I|7I}_scsKa37)wL0s6{M
zz2jn)@t^v{3E<_uuZO5+&a7t~dzZo)IoYOJQl!_L2FpG6JY3`RHa&kwmbQNJZ*e#T
zIK#+3(Dtlv@>w4v>eQhS<YVQwz>HYX$v@<wN{`R41-*n#?1?|a+gI!U#nqre4wIe7
zACod9)csE%VXmD{4kd8it*67O_W40~N2bt;q1MCSv+<nlFYuTpxj@-4C*iC)=0F{z
zID#Sj=tR3Ec)F3Um>ZO^?19N7f%&{}TKeSWK|~$Vz+^T|n+Ardp*z-;G6~{5jRqEe
z9uFKWl)Ei=1~hf<292UQHSNZ^DQE_lT%(-81PRjzG8EWU8mSS_ONzDTa^#NmR*gF$
z$T=?LT`&R->Fb@nI%c+Po31?Qdt%EW`Y|;0g<=u{-}NMP(?%kHeK~``h{Ez55_;@d
zZ^ZJm^uAlBh#=Wc2Kge*UA%}@`S4Ij`!RiN+z7zqAPhxNo-;8K!j{4}{nrk*PxYE$
zR|Pj7(;FyU<=7lH!mgjSX8){Kuyas_L9rt=tWtpu4>>ao`w9+RIiIgbik(B?^o;ec
z7XR0&pu9Jsrb|To`K#YO6Us3?oSmiri`Q4ZI+gyz<}3L4d$UVriEMAp95CvCuZ(%p
z-N{SA7j)d=pZzGyxc#rCZ2`~)$=>sZAt5L_Mt;lBP0;xhG<JmNwZCL~%?52@m_tl?
zjfcaOdaZvBGo;X>|ItQamxHOk;t0w}i$D2z2bY!kFog0UQjV)*7KVthH;>&8o$ASx
zC`tHGihm;7qJup&_=!|yAQ2PC3~k*$<Or4Ga+uJ9lLn4F*y12GNs2O-k}%W~S@~{S
z;F$OT1VJ)!e*J5u^7VQhGxVQ-LZ!LW6c6Npf>U!>P)QgPKD5T~S0y7v?xv*5f)(mF
zw2WhDJaBNxPhJ_$gmhrB5RZStx`t;+=8L>|CX|k6M0EYq^z>I#JBJL0{rf?2aCyNz
zPIN!q?u2`{u@SE`HheyCU-;rYvHF6kg0E-Iiqy|If*RUAuSag(CQ>rXC~!|tLr*cp
z?Rdjb>JCaYn_1=-aJn65J92~oBl7fulXEroFRhNaA^y1qIts{BTCrmRens3y3)O_k
zxu?osLB3<Ox|!dJ_*?569{a;Cyno*m)8RkJ3|zd=tXZ)*mgC9HJRcK-yyt}|yN?_p
zMo1Vu;_==di=IlOWt%cKW(d^OAu)fuk-p%Mc#*TL`|rVOUN16t?~WvCoxW&8`q4A_
z$mvx@Stiq~#EnnGv@I9EtHbhRmZ`$f4M5cVyB#cEj<>bR!#`SVk^~xf9Fhb^&Th@s
zJyx3M&YeAbzB%)k2pY~6lMp0Jx>rE=#a;W|W0ul-Y4s+XFDLjAe#bW-g9H(p?w%eN
z9^;aXQp2WO-Qi=n09qTaFIaY_$8}dp?7qHn(|y!?0_1TDg<b>NW0JStLN{U|b>Y>K
z;PQ+RM~>Xup~+3?Q7|zbun*AG9{!W9v{FZrjq2lF+eV3%$82i^pIh#<em!{jz6ce$
zD(<!K3s7c@NiU@h110C;cnV*sIp0}Fe1u?%D7=F(tzmf>ljZ4op)XH=Q0J<dOY8p5
zFawrmB>oL(miy-MjuIG!B@>r(FLM)~aiTLF=9%`uA@Jq;4Hrl%73uKPUx1DEm(7=e
z7&(~nId4|cXWz#`Aj#6A;m>mTqn{QXH>g5wE&hgIV_x{O1edu1082R>9?gnQG%nuw
ze!z2lb0RFTiMOa{g6=O5I#Rsdj%^QlA<GiGT#VU35Q!B+fi5fc7b_gx(k6SM;*`r7
zWwNxuX6;og0^QQjqZ{Ysy-#^y^v&qTn`o8NNHczJ`Xm!%#7U*EUngpo4&eZR1qJeg
zsm1~IYjq2)B=E$QAd>-8rr<QZ_q;!KXmmTlJ{)TKacO{3G$#68ZyXg5b+#RsuKiki
z)8{#*h=8&;Yx6%3EYV*)IG9;AY`32?8i{p^O2=CE6TWdwPmejKwKcKO>*(&xs7iD#
z2zbrDORMQQFMrQL&|@W??CpiN!tLzNl4B^sKmIaiJo^X?A7QK3#v6h^npL{s>a9?`
z7->R;>mU__p@P)%5u`~R54~pzPF7)mTjaZ53iZ8LUsS<WS9`(BRR?gU0>G~%rY300
z6maejV?B2??Ct3x&R@7h&G@Ugkj3uuaOL@(D8yJ_rjyxYJRMf={gP#_{y0Q)*B^Lk
z{z#2;4;HO;x)it>=w>lj6Q%xf{=C}-JKV@=-=M70`3TruX<i!At7VAG9U9~s2nQdi
z%69Kig4n+R_@^4Q$4k~Ib%o0#%?_o`un|1l*<s@{Z6o+0&bR(==r0`0Ffu%eAc!G-
zsY)ovGyX`%4jdROkBEC|$T0X_;7|W({l310SFFeueno-Qx>8>F&{ptwN=M!<!C`)D
zS$SKQ^A8Jl`7F=wu|R1QLsLkx_1m88FCg=@+HIhrfjWcBok1ne-JsEKoU`+1jhUu2
z-)0vg{h*a_l6NrC`hgUmBL@-iWDFr+naxe=-zzjP@5P~UR&>g$5$w&2Gv3h?LiesC
z8wbIx@k4Ie1bTN3Ad)?p+Rv7$2Qu50p7RdoZ{eA58H{ho9#0FmO5oIceWa~Z;MNa{
z9%;3;Xd#e%n)1@kj+>*+6xICelzIG{L$uC6e*OocWPM)RT;A8=DBt7th6_U`2O3f$
zRS5~D2g-OA*(Lbx+yJVPB;1ZHW{rm}zL?}ot{E@vn32!O)x`kSl;k|u*uwwR2xeC7
zE$6^r$lSf0ijH{K<=_7)f;FE%*<6Fx@7b5j+?&e;!+zh~oT}Mky1jee9OKF&IA_(d
zgPWuGZi!yD-arG2OYG0Ay;TbhL!ZAIFRsy~)$qOxM+Gm2J`E4Gn-pZojZh^d8TQ3P
z`MUUR-!7_&Xm32~i>qfTnu5bhhC}>uvP#Xykiht}p~c`J0f!j8=lwK$AE_rH{+SRY
zRNV8T^sit~f3_~-?w~mvvY~}h+<~Dsy75Xa4BLXtt+ZYc?ILadN`FoI${h)qPsPlZ
zglG*E|HE!5KarO6Wg{vo=N5DXl8rR(ck1Pg%Qy3!GDP_QiPBjpnY^;*QgJhyUnl;c
zHZZn*#lSsgUZ1DaUbgPP(rv?`-+#=o%kKy6RZ<6ol?}6kqBLv!r{4QyQGQ|<+;}ff
z^aYQPMyVssa8KW!Eo((U8ytsGa-x+D8%hT&QKdm?K%*w&`%Y3ChX`fo%6QC>7tOmA
z)jw6$nX$*)Z{PQ^2A0QzhsctXKZLYa+g~&`{@~OF>SX6+KW<$%?h~agAjdXnrgv01
z?(&uEnp_QR19cV;yQR!E!FGKj4bqc=%w)4G*~w3)QSU^0oNr&Tiw41#7&!C?4gHJn
zLmV~-Y{XC~>_IWYQT^p5aE;;n-}ab{vZxy2>EG@n|G(w%0yGe-N0CR~(D`32trzOw
z^D(ViQ)DyX?SOZ_h7p3O?#<SQ*pL;gDE=e4{wKntb_0Q*4hkw+`+m{2&B<GZSP^y)
z<TrFN4A~ZJVEQh%7_E&GH2dYUbzd02sM&V0wtQbh{-qxoK!)XxjUk>vpoA-#nu-h#
zP#1R5fzim+`AjVuO-qa3dU50z>&+X6P*f}ALg3)j`tZiP3nB2{FVh4=Y~r1D4|9<d
z&;V%WqTCzkawGxUQA(ssTPk5Da!b^X-A@!7{EBiM?UbORIPWW`AUxQb&CZ-JNw~z4
z^Jkbpi?c225)Hxk3IGH!#+)by)PRD*uCOE>R)GYVpVqCbxnsw-Ec;lE!;#>jiV~Jx
z*yRfM()m6i5Pn=2hf~vdID@Ox*!2ddic(XGJ_I(`*-bNBV!6%d@17c_a)0q+b5`t@
zuE>npn2=?jd1Wp_2pA|KQ5xr@B?i49>9x@sEGU2rNQAIjp}?<$!;q8O8Kls9Y&jfx
z9p4Li-xuczX=!=-vyY4763iH0B8q=CLg3lorKr)~M(;~cBM8z{Jqsxii~@b%xSP~T
zmGA8s@o8!Cf9;NZ65aP!+!v8MJ#bc^!_J(yN>>)Qo<GBK^k)Gz<qWbX06ruG0hbFg
z7x<Kc=(QFi>jQ)?NMfD4N71@~T%Qcc<g0i{c6lgq_BqVSK6PtdCNcs99uYAT_^|>U
zy5I>7BM{s7K_UM22i|bLUh7=i;SGvHYkY6-jeTZ^W8wxM-mqI~Rdx-HnOhw<jX*${
zF#-1DyDX>b58FhG`Rn=*O_sDJ-@W3!)U*%&>LYATm=7`H>2P4>tw{dQL?LNo<3w9^
zc5^cNfreR3M^Eq1@6CYt5mQ0gmPRjW^X-eHtglh~umdsA2JK*5KdF+FAe>SsK7IL0
zRrTe|q9v@yBuz^GWlVWGI*@w4+Y=Yzum0PfXS9jK4lgH@)Ce_$M~YWA<J4U6+Y^h`
zFqg(ymJqgM`D>EczXAm1u`yz`p=iAQF6PE*_;~H3_V(zQ4S`nA(dT$UmmRSy!(OyN
zxQFVDZw}Xp=xJWN3CVBC=rVS-9D6Zkm}cKS(4x0?5~*|az89oMUeZUoK`AK&QCUU2
zj<A@wOD4G^exr_UipciS0>_YJaF;nPpMG{npiS7%W2JWjq*%)&p@?nq6Yu@vV-|KV
z{y)3dzQn&j5~<hRMqj9ng{&X&!g+awYbZb8C-)O1^}Ys?U&D*)&>D8WGvQ!<F&s)5
zdNdSaou$lI#R!_k|9jNI+CO23%o%thmp>WEQ6Z`k?#nOXjAnYOD8E{D>DMqN-3d0B
z2&&Mu;V~it7fUVt7|zcQFfeg+5}O>lZkZ6|y~`#jJo9szFN3c|FqB6AN9%<t4`6}B
zvWwRjb0(C^2~KfU)c}Z{|IG8A{a|F>j|+X>Yxp|qzgB~YZ&&@$@IbuUQl007v@XDf
zv-`K(2gC!A-*&2<)Wd|S$TA>Mw89$;>7l2>w$T#5TX87J&5Q`O-C7}n2-}?nWDX_U
zO`ki3596hLDS6X$dKo7-{amQT=yE;)^7&7bp+L`)dyD$#Za?-at{&7Iat}9!1Bmc*
zI=QlcJgr-{inqS0i{i&Quep5$exh@G4NqUVY3k@efk~i|b&}1S&Gy>b@rp-Smo9NS
zr^bQ%WVQsrjZToxM48Qt84<w+yp=ajj60Vu1<OmnHB_=He_z`bl<AO<#1^tB5kt~~
zWOW-vl++=QT2L=7%eGeY53B+sqFj2`=44(+2T!x*WS>OMVtjUzRggVj<62Sy9&%NY
zNE*5RwCnZMI@1~(2iTZ;|G>aMv1ax_f4_;@+Rf~)t95VMl(;Suw|u#K`}WolQq{OS
zI@qrN3miN&)_V4Z=jyKZag)(Flgsk}wC}fxM(u`9v&*0~_n8g&*cZFYJ7yP2;^aks
zXkVbo&}bxx#f*v@8%kVl?UywPscrt!nP=SM4c2%M;eMhR%D|!x<<8RL$$00Dw<Q9Z
z@5G5*?W$EJ*#gNY4?d-uaJJ;wS0f|iM<tS@Bba#ZnApzr@N|?$<_o*}>rmVVN+Zw2
zedi5FaZvjAgx!*h*BH4`qIw4OcE!+8#oG|0UKGX1y>?NuJE8pLpAhVzVT}XPN%Zof
zhVH%GV%xvsA3g1e7LA`1L|&1X;}sNHiQ|<dRdF!zH=NkRFnb96x2mv@7gkNO72_Md
z9BKWhY3twf7W-L+&i;Ov43MIluit?<eqWy}IC!MvK*y1TdlB)5kzHc(u8|F`lyhB9
zTTBARC_E-msrM}ek4KQ0`v1T91~d4*Fy14{xkN}y&_$}5q8iAeODQFOEl}#%s9If#
zu2m19R}2QqQuL^W7;(eE$?fe#8O^7q5BB*U2C?zhhvtJE=e1Bk!AuxYj+c0m!|{Cu
z-A*E)G^wJfo1FwFCV04lUtk<<(EZZG7F)ju-Tk&66M`%&hyp=tk!6zISMM3#|Czj2
zM*8ld5AH<vH=#59&hU`*?BY2oN34hyIg&ERalrUMkQyVzgQ}a`Uqt71n&S~A1`mj0
zhodp&;{QB(^719s;{i$6sBEWGAy>rE{T}_9DcuVFSBK_^P*%I>&ze^`h|f^UIW)<7
zBGLSb@~BjG!<-lg&J$lB(0>l>zw`V^mL(7JNH7A8>(iI4C&E~kWH!A`uKAvM`3nDi
z;I&kB<#KJ-+8gM&;i%xon4Hc?9ifg07(znttI#tGJMH#dz-K}-(~?gc5hMK6g}T5_
zpBiY672@yk)3#C9;AzM@XO0zu4m_p86aM?R`Ck>OPY-}$vtKOCmTjUVPrs6NMtl)E
ziEM>fwv8JRKC=<aOn|C_;}brd4h_|IR<u98;|H?cXy_~EcjtcC5kU1Gv{9R>TKh9m
zZ^=~uyw;Z}(nRe0of>FG+(5{q#DQ;lY-I%V(c_@=bk4jnS@@mh$*dm(52CGIF&P75
zRe};PxQ4FuO-|3scJ?t8!lI9c?DmoTcO+5{_UdKKfgCK{et%y=YtPQH?`pJA9U5)1
zGje+^LJgmckp-c5iaf7L-7Znx4<i1-TbKXenJ>~Si&mNEu(^XnU{zU>QZJI8`2X0g
zgM85sbs`swE6Sc@X5QHcquLU@qYUi4NAy6xF!uQquIlg&Q}$b;b}rG0==$SXbhRI8
z>qq-xz<w{hPmPP5#I#OFL>HCTiTypbqHRjVa`k|k9bb`aGTL7B7qt1NQSFI0YSVBm
zwHtqlB8O$r8x>Z-*($U8;F5sc9;it>x-P1?yCSH+a>=@Dqp&^-84l}FmCV7LYk+T{
z5;uIGO1NxC1O@osP<bJH8Fvpwvj283eG`#<?S$jh=gt;d%R&~KdN;3iD^UWJUYl(*
zs){~>XEDCi@V?{Ay4RFi6NKsdB*lol=`NbmorZrqhAnR3lbctjzCKGQfKS3iLC0Bb
zrkiO_Xa0sZKzmL2N1d?Y4}i7?e_c4rTko!$B;W_|Z<ORc3)MSE@y2s~p$^+PoIf_3
zLYoc`{Kko#d}-I)0h|>lQ2P5rTZI=uemAQQWb1+r@*s3#-XOVPuY*AporU}(Au18x
zh{E)c<H8d8X{$EdGmaH{_2SQAVLyK}(OR^ElV!}JMgJ9U+p)`^Ly_G-zwhm${oL<2
z(kqt!0mHlBZ6)-hIw6V*uIeZSE+wH5p-Lm^5X21=-iTQwh(wVjf@YtP2l!GRIak9$
z`Petm0YPcsc4hpfKG8QJVnSTv9+MWu{WfO0zVLKg&mOTE4y(|X%6@I00TwMm(7nAF
zNDbd<MhE?@yJ#CG2xu+3)*GH}7f>GNU_S@Ssy5Kor)=IbKx|AMo_p}Xrg#5Fkm_W)
zTxTI6A2-K<O7K?Jk&xY!kCEVD76}SEDS2>p4-(v6F$)NL$`Ey}|4b#=eh`TL%TJLI
zGQqI20(`m%Ev3_!LQq>!+SX8i^3(+t*!@1#1?`CXtux=-F4k@^PBCQWnmt-YTuObg
zUOpiBak3$UvF!=nyt*^>IN8SCi0qKzdfB&6+rxd+d`qwf-e3kqR~Sri2h9r?QEIj0
zM%-R%wMFzzB;>Upi~@sg>obNCGlJ(<j4_peR~WMU+BcubKHNMCsRJKRz>r^7q&LN=
z4>1?aq(kbM^7MB<B%#R2Zl<Ik-Ta~K*yD*)Avd<Y&LfRYR3}t}dXsC;Wl|g9Hl<Ny
zq^1`b@79<#%$YjT>U)}894mA8qQF^B;SKgp`ww{TzNc%xR=ABkqVD%)j=rpbFcbl8
zwsZ`;m3Gb7LA#8#4hCA<9Is`3mhVXz`0c3ZwfYcwo?HGR3+mrtu>}{mPq-na-!5N=
zulM)=(!k3PKHhQTCV))oHz1joY~Hlk;7uQ>`vv0zYe}*(#JtCC_BBUQI&lFWmv|F%
zYglkZFh)$MvCh0>abPqoIc1had=bP~HeQJ(d}5>*7mfH+ZRy1!bDNz?OyYwJw&^3G
z=^5kxA3BSQ=*DA#LAEUYdCz!~yde^E(nO@T(d{FkZ@%*_YcoH3xSos52HxDj3TRiz
z`Yd`^7%6pp*)J5Ve=sDI4&7fbfYm3X1*|&{Qach4hVkg1_UxD)sObODax%2H%Ud5Q
zwZ1pUdNXkad~%<+=*QH>D-%|7+{)c}xpqRlACCLQPt)U8k9p1-uXx5QVsaqoj?&B}
z9SEZ4d?v4(H~iiFuuF=SN;G1q;?syy2T6I{9(BOaUlQi(|3`^gZ{FpwVkaW0_Spj<
zA^=yN9h+?Y)az@|P%}m%-ii4IxgPM7$$}Q06qIGG%B3ms3sJA3qBpK>=p>){uje8(
zi1p;>VI!isTvT53H(*D&J!M9(g|q(*U$R5)^ewx6C3j0?8%}pno=gcL8#hT@Gy5nM
z*~8(+g$rsV5EMfc7dch^HQ|ApB+BrW3)TMn*wAVDp&SR0G9!h|;dx_II$Z+>(xU<z
zpA(S^63t8i8riV?X^Efrt$3qzhO*MIHY?(l5#BgH=LnMdQ=iQ)LI420U0cW3QqdzT
zuN!&&70P<|rd;2W@s4_aG*P(t$`M&O0D!c7yVzW<4r;w)>G)DBWRTf2&Cmzt(jK>O
ztAL|ct7}ly_vpQl$f)<0(`avqp!<f_Fz_TEBNF!>s-b92ui6bYtlBqDJNy8BYR1_J
z&`}m!$JCGZBj)rt(`U%~FyNbiK&Naa4;<bW&0XqS|8(8G8Ta}FTdd&K?shw%4Gdh_
zW?=XiL78p~cTD&Y53W4>@!|9DeGoG*_Cau%UIm6kENef5vIB{4_7XTNUr$!YoD`PU
zab?VvLP>+4VQ%ybb~c#s3+!DyR6A5_$sGA#5dLr5mLYU22|nYfy)ZYEO>ypjCaSaR
z%nSj=u|69Yz=R2u-$vfa;YCUgU){zNhh3^VwmoT^BG_q$>#!%bjb_+Nw=vF=$V@QQ
z+Z>Va2vmezPN)QF+DGz0en!4<`%33=Q6s&9LUkrTFteutJ8OvoA)?TWhD3Tr`WS!i
z0^ZXUAOPOc0IlOc?ZSc+a&YB+<=GH~B|8#jAB8@1m%eTo-!BdS@a1RGS=2uti9~*`
zstb^&Dc(H&=?_vmLrjWA1cMifAxQohMns9oi@>nrfW!%U@VsA1aNO~q&=udSwnGir
zk6*#*AqWf-Pud!4D|Iboq8`yj1y1En&{}HiB0;+}$<MCnsNR3Wi_|Y{x0aavGu>o<
z^x*1kbYCJMr^G+_KQgMhG4?>aHe8#%IfI`aY^Yzs;9mR35zka@wdct7+R>Mk-z@SX
zaoRJiWZPS99N3Qz@op$pmAoS@@p1fgg3DNG7wD~d;^HxG$L%sTmZV1nkc6i4?NtqS
zIKJBciSqLac>Thv*S0Td^ymO@XWDxi2S5bi5ghBs!1%LLd_jzfGGmmWy`ZNr97NP+
zMXk`>3_JoI2t#}!;=y7hHrEoH5T4EH0Rq8L%Vk@tDhHt8sX4KEH&3IVe>Kxq(fw?d
zckjkzGN?{?)Cc*#v%DhQCWm2-u@AMO!}(ML97tr#APGPaw<Gapdw`!-$Q8n7tWYJa
z5DQh62qRgNjlp;q`%8lpvE<))b?h1QCSD79r#<=av-S=7=Wz70&Vp)^E#?<mb~k3r
zGVh~S6N-(%e7vJjm1CSr@%$vF(le$0i-C*G&Yf+{a}R-gS2>*^?Gc~xLh;7uY%|R9
zmX-McO?WOd&*jYHD&qV4(Nh;+!Ob(yCG|VF*thT*5O23m(}|m#)?&9lfwk@@6F*e^
zOSEg>HG5vbdi>dGVBX<ffWWz+Jf>)S71I9Ot`b!=C>z;a0iJPAAVD|9SDB+1VaANV
zuQt-S+@3#u`Q{jvswkxcIlYZct}ARZUYyQa(aOFjUCQlX4n>wl|M+?TiH+~yzENJf
znQS#|Mo<23N%=ekU^vR!fWs*%r^qI^oka1|btw-o@uS1nh!UhpoTXeSW1Ur~*qPh*
z%q4b}bFxbdSFTP9lW$`|@2qUP#dqnL3*$_2Zq1`-I^;93QGQbvh_@pNp;=XyWOeoz
zavA=EOS8Qo_%MRBLts{bq~0DuOQJ~#G+_dX{M#i;T|qDw3-CmV(>%7ui7~M!@v_{m
z!q~!H9Ejc|-Rs$M=URvEAf-VYKe=@0zWg0acJ4Uy(901a^71xQ0rLtVFn_W0-4x>N
z4uH*VdY<dN2)ggj`vttZJ>w@!-CVxkZ%U{yZh5JJ7FD*E7q5+%4mAGpvLPuE&6aU8
zLd{Kr@R#4JBi%f@XrP31Un|^2>_LN{2zyd4I^?x~m6vz@fmMyOFSRxNCfS_#RXZ5N
z&eaf!`W3|lpuhz6pplW`D<Z>8MXG}C0IYsDUU+*p=6l()Z!a95@7+F0DJ30@hyhp}
z+1O9;>krBa#3u}Ig2fPt;cI<@_4^lFy(_5RmRGWY8iqWQ2RQ}o*Tzi}WR;g1C}!pX
z&fNoji|sV*+XK{`!uR6dB8B6WqSl-{I5H%&cDE1CZ{!uyxf%Cs=M<kE;iGcruG(P#
zy>m*@s;^kMD+joel%O9|6BJhYo77=8MI}gST~a|(dy1(8KeX>5Z0cy;kSLS7q%;9e
zT#+O5&&Jl%$D|zD@<KvcrXMHC_mgB(roSxVh3Kl@nO^8Ww$+&&Qjk*jBw-RG9xX27
zF>pTE7gOR#szm=m*(y^J<p*AVz!j<#6lINeg^Vz&N-oJFoAsqHnU00os4!K3E7Q#!
z2K_JyRr@b2FPj^ag?uTbLa4&8)|4=|ASx`*ubC_&8%aO=DE^Yn_Oe?30yeXPS;77$
zEF@EbNBjE+Q~uF_K&8`x%YSZgCH~*W@biBd&i?OZ`cHXr!4@h~Q%DUo)F!F^uU&ug
z-I&mKUOd5zncC+!j_QECt7s}pe(+q#*TWZH(qkV3ggS)1xTQr3{z~_u0C?k)^6LTK
zU6M}Ve-zLLKoivL0v2aPp-PtEm5cX|O#K(faZ^7<I0Vfb-<!l!*{bI*E=1V0VvO?b
zjfgX@6w^i~uP&bG)xXU+^v$>hkEJx6W$h?VFcR$^kHB#(o2#(UC~{fk8s5rdyuMx=
zCyA2_jx03b0El*IoMz%m+_nNn(|a0|Q`}yDjpZo|s6@<pNZ;M&nE0FC?t0`p8KvOs
zGJpxi4v0f;F|1>5manlGbsYqTk3AX*r_+u`rv0|J=2?zbRaZv1Afn4|u7@$h!pE_(
zkc*sm>z>D2rz^%vU6-vYIIjbyz{L>Ui>>Tq#^<HMVuo@x<^|5eh4u-!V4{y{Vd>=R
zE!%`Awsg+eTsa&X<bhimS2T2^o__mTTrg5#5d&xuJ$d>ZRIV<CW}=>M&$2Lb&I@`Q
zs7(^z^kVpX%rNW$tZ9YwS|{Kfnyu}A0SIKLttu?Gn8tC7Xynnj&Z5lh8F^Lp1*7Wc
z+p3~NwWhpEj66}BA*9$V$heBlvtlj0xU6C$zD|Xh(@x)$`0FtN;b-7bAM80Efpvk(
zV~&<v-l5nR;a~1Wd2EaWqatQ~JLDXgw~@MRK^-&DZS-?SV4g<iTZ_4MPNe+zH|W+#
zfmxJ{^D<&v|Dr|QV5o)i`{3|3=|?Xt5)UIY-3H?uys!Ht9GG?bs08IAZ#o<(j)SES
zL6B61{zn2e`mbQ}4K59Shd?b^%ZFj&fbLIi7GQcA`y6=#n-bn*9h`j9BVOZpHwY32
zBeU?wtz6KtEzz>bHHF;5yE|t8U*yTM$z6)Z)PfaLBqR<5i6fa;(cz`V*60zx#|(VV
z#{UvKVHOpF^6~kcqKagvXL#Mf8jj7r`yVYXpD!>fW)A+vDx&v;-Euz*7c1J=)7x`>
zBTO%B;;tD!A{X5q7b#5MT*i;|iJq;ZdTj6#;>haDbvovvk^%l{9RFugAvg`i({sxZ
z%{~7i-)ds5Hzp-Sl|ty65<Q_~#A!6D+bSMk#jCZN{q<J4L3{}NCpg&Ux*NW_hg3P@
z#zw5hwl)3TIvwhB5y%v4v|=ewQ+ro<btfKuDwH6JTnQzGp}jdVw?0#Xm>`5$HXEFL
z-AY-na`$0@eApa)pZk;8**x94XMrNHsnNS+v?RE~<j&I6u*PD^c`GJzWUd^Md!pUM
zZ~Wk^z8V1|8!(?OS1xU-e{nQJD!ahBOV~2|Z(|X4AR$T478IvVejGbLki@E@OVn?>
zxqax(M(ebRkTPfaIH`a=arLyazs?13Fy}w$KT$nErS&oA`~E)v*$WXp(xA7-jgvCr
zSkb8d%{Z2sx>qU%KZ5B+TN`B`&vx!dZ5{l@YzqO1bv?_Zw<XKA%$=94+-;mv{76MR
zVC6y+BExNrPhi*V=rN<2-Z7y5b;v04du<;GA8uVhsi$s8ybV$r{|2CJgmBVtBb35a
z8)32?myYWj5i~yblZ9mTFB<H$%YJ(d*=n0%g2fhEWGO+jop#!4yDh8)Eq2(fl%URb
z+X+^;@Ovw6OO9-@$7tXNOl_-dG`#Z-*=Sa`*ledA0S50@BLcV4^G)!>ncK7RTc+Sj
wV~wC{s9hK}Y*V5<F|+%Yk&N8l2o0RD=S#(mOZxN;nMx*-=6L<R{U6O@00w$E-2eap

literal 0
HcmV?d00001

diff --git a/nok.png b/img/nok.png
similarity index 100%
rename from nok.png
rename to img/nok.png
diff --git a/ok.png b/img/ok.png
similarity index 100%
rename from ok.png
rename to img/ok.png
diff --git a/wait.gif b/img/wait.gif
similarity index 100%
rename from wait.gif
rename to img/wait.gif
diff --git a/index.php b/index.php
index 47ccd13..dee80e4 100644
--- a/index.php
+++ b/index.php
@@ -1,7 +1,21 @@
+<?php include "connect.php"; ?>
+<html>
+    <head>
+        <title>TablIP</title>
+        <link rel="stylesheet" href="css/style.css"/>
+        <link rel="stylesheet" href="css/icons.css"/>
+        <link rel="stylesheet" href="css/materialize.css"/>
+        <script type="text/javascript" src="js/script.js"></script>
+        <meta name="viewport" content="width=device-width, initial-scale=1.0"/>
+    </head>
+    <body>
+        <script type="text/javascript" src="js/materialize.js"></script>
 <?php
 if (isset($_GET["site"])) {
     include "siteNetworks.php";
 } else {
     include "sitesList.php";
 }
-?>
\ No newline at end of file
+?>
+    </body>
+</html>
\ No newline at end of file
diff --git a/js/materialize.js b/js/materialize.js
new file mode 100644
index 0000000..1e18382
--- /dev/null
+++ b/js/materialize.js
@@ -0,0 +1,12374 @@
+/*!
+ * Materialize v1.0.0 (http://materializecss.com)
+ * Copyright 2014-2017 Materialize
+ * MIT License (https://raw.githubusercontent.com/Dogfalo/materialize/master/LICENSE)
+ */
+var _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if ("value" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };
+
+var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
+
+function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+/*! cash-dom 1.3.5, https://github.com/kenwheeler/cash @license MIT */
+(function (factory) {
+  window.cash = factory();
+})(function () {
+  var doc = document,
+      win = window,
+      ArrayProto = Array.prototype,
+      slice = ArrayProto.slice,
+      filter = ArrayProto.filter,
+      push = ArrayProto.push;
+
+  var noop = function () {},
+      isFunction = function (item) {
+    // @see https://crbug.com/568448
+    return typeof item === typeof noop && item.call;
+  },
+      isString = function (item) {
+    return typeof item === typeof "";
+  };
+
+  var idMatch = /^#[\w-]*$/,
+      classMatch = /^\.[\w-]*$/,
+      htmlMatch = /<.+>/,
+      singlet = /^\w+$/;
+
+  function find(selector, context) {
+    context = context || doc;
+    var elems = classMatch.test(selector) ? context.getElementsByClassName(selector.slice(1)) : singlet.test(selector) ? context.getElementsByTagName(selector) : context.querySelectorAll(selector);
+    return elems;
+  }
+
+  var frag;
+  function parseHTML(str) {
+    if (!frag) {
+      frag = doc.implementation.createHTMLDocument(null);
+      var base = frag.createElement("base");
+      base.href = doc.location.href;
+      frag.head.appendChild(base);
+    }
+
+    frag.body.innerHTML = str;
+
+    return frag.body.childNodes;
+  }
+
+  function onReady(fn) {
+    if (doc.readyState !== "loading") {
+      fn();
+    } else {
+      doc.addEventListener("DOMContentLoaded", fn);
+    }
+  }
+
+  function Init(selector, context) {
+    if (!selector) {
+      return this;
+    }
+
+    // If already a cash collection, don't do any further processing
+    if (selector.cash && selector !== win) {
+      return selector;
+    }
+
+    var elems = selector,
+        i = 0,
+        length;
+
+    if (isString(selector)) {
+      elems = idMatch.test(selector) ?
+      // If an ID use the faster getElementById check
+      doc.getElementById(selector.slice(1)) : htmlMatch.test(selector) ?
+      // If HTML, parse it into real elements
+      parseHTML(selector) :
+      // else use `find`
+      find(selector, context);
+
+      // If function, use as shortcut for DOM ready
+    } else if (isFunction(selector)) {
+      onReady(selector);return this;
+    }
+
+    if (!elems) {
+      return this;
+    }
+
+    // If a single DOM element is passed in or received via ID, return the single element
+    if (elems.nodeType || elems === win) {
+      this[0] = elems;
+      this.length = 1;
+    } else {
+      // Treat like an array and loop through each item.
+      length = this.length = elems.length;
+      for (; i < length; i++) {
+        this[i] = elems[i];
+      }
+    }
+
+    return this;
+  }
+
+  function cash(selector, context) {
+    return new Init(selector, context);
+  }
+
+  var fn = cash.fn = cash.prototype = Init.prototype = { // jshint ignore:line
+    cash: true,
+    length: 0,
+    push: push,
+    splice: ArrayProto.splice,
+    map: ArrayProto.map,
+    init: Init
+  };
+
+  Object.defineProperty(fn, "constructor", { value: cash });
+
+  cash.parseHTML = parseHTML;
+  cash.noop = noop;
+  cash.isFunction = isFunction;
+  cash.isString = isString;
+
+  cash.extend = fn.extend = function (target) {
+    target = target || {};
+
+    var args = slice.call(arguments),
+        length = args.length,
+        i = 1;
+
+    if (args.length === 1) {
+      target = this;
+      i = 0;
+    }
+
+    for (; i < length; i++) {
+      if (!args[i]) {
+        continue;
+      }
+      for (var key in args[i]) {
+        if (args[i].hasOwnProperty(key)) {
+          target[key] = args[i][key];
+        }
+      }
+    }
+
+    return target;
+  };
+
+  function each(collection, callback) {
+    var l = collection.length,
+        i = 0;
+
+    for (; i < l; i++) {
+      if (callback.call(collection[i], collection[i], i, collection) === false) {
+        break;
+      }
+    }
+  }
+
+  function matches(el, selector) {
+    var m = el && (el.matches || el.webkitMatchesSelector || el.mozMatchesSelector || el.msMatchesSelector || el.oMatchesSelector);
+    return !!m && m.call(el, selector);
+  }
+
+  function getCompareFunction(selector) {
+    return (
+      /* Use browser's `matches` function if string */
+      isString(selector) ? matches :
+      /* Match a cash element */
+      selector.cash ? function (el) {
+        return selector.is(el);
+      } :
+      /* Direct comparison */
+      function (el, selector) {
+        return el === selector;
+      }
+    );
+  }
+
+  function unique(collection) {
+    return cash(slice.call(collection).filter(function (item, index, self) {
+      return self.indexOf(item) === index;
+    }));
+  }
+
+  cash.extend({
+    merge: function (first, second) {
+      var len = +second.length,
+          i = first.length,
+          j = 0;
+
+      for (; j < len; i++, j++) {
+        first[i] = second[j];
+      }
+
+      first.length = i;
+      return first;
+    },
+
+    each: each,
+    matches: matches,
+    unique: unique,
+    isArray: Array.isArray,
+    isNumeric: function (n) {
+      return !isNaN(parseFloat(n)) && isFinite(n);
+    }
+
+  });
+
+  var uid = cash.uid = "_cash" + Date.now();
+
+  function getDataCache(node) {
+    return node[uid] = node[uid] || {};
+  }
+
+  function setData(node, key, value) {
+    return getDataCache(node)[key] = value;
+  }
+
+  function getData(node, key) {
+    var c = getDataCache(node);
+    if (c[key] === undefined) {
+      c[key] = node.dataset ? node.dataset[key] : cash(node).attr("data-" + key);
+    }
+    return c[key];
+  }
+
+  function removeData(node, key) {
+    var c = getDataCache(node);
+    if (c) {
+      delete c[key];
+    } else if (node.dataset) {
+      delete node.dataset[key];
+    } else {
+      cash(node).removeAttr("data-" + name);
+    }
+  }
+
+  fn.extend({
+    data: function (name, value) {
+      if (isString(name)) {
+        return value === undefined ? getData(this[0], name) : this.each(function (v) {
+          return setData(v, name, value);
+        });
+      }
+
+      for (var key in name) {
+        this.data(key, name[key]);
+      }
+
+      return this;
+    },
+
+    removeData: function (key) {
+      return this.each(function (v) {
+        return removeData(v, key);
+      });
+    }
+
+  });
+
+  var notWhiteMatch = /\S+/g;
+
+  function getClasses(c) {
+    return isString(c) && c.match(notWhiteMatch);
+  }
+
+  function hasClass(v, c) {
+    return v.classList ? v.classList.contains(c) : new RegExp("(^| )" + c + "( |$)", "gi").test(v.className);
+  }
+
+  function addClass(v, c, spacedName) {
+    if (v.classList) {
+      v.classList.add(c);
+    } else if (spacedName.indexOf(" " + c + " ")) {
+      v.className += " " + c;
+    }
+  }
+
+  function removeClass(v, c) {
+    if (v.classList) {
+      v.classList.remove(c);
+    } else {
+      v.className = v.className.replace(c, "");
+    }
+  }
+
+  fn.extend({
+    addClass: function (c) {
+      var classes = getClasses(c);
+
+      return classes ? this.each(function (v) {
+        var spacedName = " " + v.className + " ";
+        each(classes, function (c) {
+          addClass(v, c, spacedName);
+        });
+      }) : this;
+    },
+
+    attr: function (name, value) {
+      if (!name) {
+        return undefined;
+      }
+
+      if (isString(name)) {
+        if (value === undefined) {
+          return this[0] ? this[0].getAttribute ? this[0].getAttribute(name) : this[0][name] : undefined;
+        }
+
+        return this.each(function (v) {
+          if (v.setAttribute) {
+            v.setAttribute(name, value);
+          } else {
+            v[name] = value;
+          }
+        });
+      }
+
+      for (var key in name) {
+        this.attr(key, name[key]);
+      }
+
+      return this;
+    },
+
+    hasClass: function (c) {
+      var check = false,
+          classes = getClasses(c);
+      if (classes && classes.length) {
+        this.each(function (v) {
+          check = hasClass(v, classes[0]);
+          return !check;
+        });
+      }
+      return check;
+    },
+
+    prop: function (name, value) {
+      if (isString(name)) {
+        return value === undefined ? this[0][name] : this.each(function (v) {
+          v[name] = value;
+        });
+      }
+
+      for (var key in name) {
+        this.prop(key, name[key]);
+      }
+
+      return this;
+    },
+
+    removeAttr: function (name) {
+      return this.each(function (v) {
+        if (v.removeAttribute) {
+          v.removeAttribute(name);
+        } else {
+          delete v[name];
+        }
+      });
+    },
+
+    removeClass: function (c) {
+      if (!arguments.length) {
+        return this.attr("class", "");
+      }
+      var classes = getClasses(c);
+      return classes ? this.each(function (v) {
+        each(classes, function (c) {
+          removeClass(v, c);
+        });
+      }) : this;
+    },
+
+    removeProp: function (name) {
+      return this.each(function (v) {
+        delete v[name];
+      });
+    },
+
+    toggleClass: function (c, state) {
+      if (state !== undefined) {
+        return this[state ? "addClass" : "removeClass"](c);
+      }
+      var classes = getClasses(c);
+      return classes ? this.each(function (v) {
+        var spacedName = " " + v.className + " ";
+        each(classes, function (c) {
+          if (hasClass(v, c)) {
+            removeClass(v, c);
+          } else {
+            addClass(v, c, spacedName);
+          }
+        });
+      }) : this;
+    } });
+
+  fn.extend({
+    add: function (selector, context) {
+      return unique(cash.merge(this, cash(selector, context)));
+    },
+
+    each: function (callback) {
+      each(this, callback);
+      return this;
+    },
+
+    eq: function (index) {
+      return cash(this.get(index));
+    },
+
+    filter: function (selector) {
+      if (!selector) {
+        return this;
+      }
+
+      var comparator = isFunction(selector) ? selector : getCompareFunction(selector);
+
+      return cash(filter.call(this, function (e) {
+        return comparator(e, selector);
+      }));
+    },
+
+    first: function () {
+      return this.eq(0);
+    },
+
+    get: function (index) {
+      if (index === undefined) {
+        return slice.call(this);
+      }
+      return index < 0 ? this[index + this.length] : this[index];
+    },
+
+    index: function (elem) {
+      var child = elem ? cash(elem)[0] : this[0],
+          collection = elem ? this : cash(child).parent().children();
+      return slice.call(collection).indexOf(child);
+    },
+
+    last: function () {
+      return this.eq(-1);
+    }
+
+  });
+
+  var camelCase = function () {
+    var camelRegex = /(?:^\w|[A-Z]|\b\w)/g,
+        whiteSpace = /[\s-_]+/g;
+    return function (str) {
+      return str.replace(camelRegex, function (letter, index) {
+        return letter[index === 0 ? "toLowerCase" : "toUpperCase"]();
+      }).replace(whiteSpace, "");
+    };
+  }();
+
+  var getPrefixedProp = function () {
+    var cache = {},
+        doc = document,
+        div = doc.createElement("div"),
+        style = div.style;
+
+    return function (prop) {
+      prop = camelCase(prop);
+      if (cache[prop]) {
+        return cache[prop];
+      }
+
+      var ucProp = prop.charAt(0).toUpperCase() + prop.slice(1),
+          prefixes = ["webkit", "moz", "ms", "o"],
+          props = (prop + " " + prefixes.join(ucProp + " ") + ucProp).split(" ");
+
+      each(props, function (p) {
+        if (p in style) {
+          cache[p] = prop = cache[prop] = p;
+          return false;
+        }
+      });
+
+      return cache[prop];
+    };
+  }();
+
+  cash.prefixedProp = getPrefixedProp;
+  cash.camelCase = camelCase;
+
+  fn.extend({
+    css: function (prop, value) {
+      if (isString(prop)) {
+        prop = getPrefixedProp(prop);
+        return arguments.length > 1 ? this.each(function (v) {
+          return v.style[prop] = value;
+        }) : win.getComputedStyle(this[0])[prop];
+      }
+
+      for (var key in prop) {
+        this.css(key, prop[key]);
+      }
+
+      return this;
+    }
+
+  });
+
+  function compute(el, prop) {
+    return parseInt(win.getComputedStyle(el[0], null)[prop], 10) || 0;
+  }
+
+  each(["Width", "Height"], function (v) {
+    var lower = v.toLowerCase();
+
+    fn[lower] = function () {
+      return this[0].getBoundingClientRect()[lower];
+    };
+
+    fn["inner" + v] = function () {
+      return this[0]["client" + v];
+    };
+
+    fn["outer" + v] = function (margins) {
+      return this[0]["offset" + v] + (margins ? compute(this, "margin" + (v === "Width" ? "Left" : "Top")) + compute(this, "margin" + (v === "Width" ? "Right" : "Bottom")) : 0);
+    };
+  });
+
+  function registerEvent(node, eventName, callback) {
+    var eventCache = getData(node, "_cashEvents") || setData(node, "_cashEvents", {});
+    eventCache[eventName] = eventCache[eventName] || [];
+    eventCache[eventName].push(callback);
+    node.addEventListener(eventName, callback);
+  }
+
+  function removeEvent(node, eventName, callback) {
+    var events = getData(node, "_cashEvents"),
+        eventCache = events && events[eventName],
+        index;
+
+    if (!eventCache) {
+      return;
+    }
+
+    if (callback) {
+      node.removeEventListener(eventName, callback);
+      index = eventCache.indexOf(callback);
+      if (index >= 0) {
+        eventCache.splice(index, 1);
+      }
+    } else {
+      each(eventCache, function (event) {
+        node.removeEventListener(eventName, event);
+      });
+      eventCache = [];
+    }
+  }
+
+  fn.extend({
+    off: function (eventName, callback) {
+      return this.each(function (v) {
+        return removeEvent(v, eventName, callback);
+      });
+    },
+
+    on: function (eventName, delegate, callback, runOnce) {
+      // jshint ignore:line
+      var originalCallback;
+      if (!isString(eventName)) {
+        for (var key in eventName) {
+          this.on(key, delegate, eventName[key]);
+        }
+        return this;
+      }
+
+      if (isFunction(delegate)) {
+        callback = delegate;
+        delegate = null;
+      }
+
+      if (eventName === "ready") {
+        onReady(callback);
+        return this;
+      }
+
+      if (delegate) {
+        originalCallback = callback;
+        callback = function (e) {
+          var t = e.target;
+          while (!matches(t, delegate)) {
+            if (t === this || t === null) {
+              return t = false;
+            }
+
+            t = t.parentNode;
+          }
+
+          if (t) {
+            originalCallback.call(t, e);
+          }
+        };
+      }
+
+      return this.each(function (v) {
+        var finalCallback = callback;
+        if (runOnce) {
+          finalCallback = function () {
+            callback.apply(this, arguments);
+            removeEvent(v, eventName, finalCallback);
+          };
+        }
+        registerEvent(v, eventName, finalCallback);
+      });
+    },
+
+    one: function (eventName, delegate, callback) {
+      return this.on(eventName, delegate, callback, true);
+    },
+
+    ready: onReady,
+
+    /**
+     * Modified
+     * Triggers browser event
+     * @param String eventName
+     * @param Object data - Add properties to event object
+     */
+    trigger: function (eventName, data) {
+      if (document.createEvent) {
+        var evt = document.createEvent('HTMLEvents');
+        evt.initEvent(eventName, true, false);
+        evt = this.extend(evt, data);
+        return this.each(function (v) {
+          return v.dispatchEvent(evt);
+        });
+      }
+    }
+
+  });
+
+  function encode(name, value) {
+    return "&" + encodeURIComponent(name) + "=" + encodeURIComponent(value).replace(/%20/g, "+");
+  }
+
+  function getSelectMultiple_(el) {
+    var values = [];
+    each(el.options, function (o) {
+      if (o.selected) {
+        values.push(o.value);
+      }
+    });
+    return values.length ? values : null;
+  }
+
+  function getSelectSingle_(el) {
+    var selectedIndex = el.selectedIndex;
+    return selectedIndex >= 0 ? el.options[selectedIndex].value : null;
+  }
+
+  function getValue(el) {
+    var type = el.type;
+    if (!type) {
+      return null;
+    }
+    switch (type.toLowerCase()) {
+      case "select-one":
+        return getSelectSingle_(el);
+      case "select-multiple":
+        return getSelectMultiple_(el);
+      case "radio":
+        return el.checked ? el.value : null;
+      case "checkbox":
+        return el.checked ? el.value : null;
+      default:
+        return el.value ? el.value : null;
+    }
+  }
+
+  fn.extend({
+    serialize: function () {
+      var query = "";
+
+      each(this[0].elements || this, function (el) {
+        if (el.disabled || el.tagName === "FIELDSET") {
+          return;
+        }
+        var name = el.name;
+        switch (el.type.toLowerCase()) {
+          case "file":
+          case "reset":
+          case "submit":
+          case "button":
+            break;
+          case "select-multiple":
+            var values = getValue(el);
+            if (values !== null) {
+              each(values, function (value) {
+                query += encode(name, value);
+              });
+            }
+            break;
+          default:
+            var value = getValue(el);
+            if (value !== null) {
+              query += encode(name, value);
+            }
+        }
+      });
+
+      return query.substr(1);
+    },
+
+    val: function (value) {
+      if (value === undefined) {
+        return getValue(this[0]);
+      }
+
+      return this.each(function (v) {
+        return v.value = value;
+      });
+    }
+
+  });
+
+  function insertElement(el, child, prepend) {
+    if (prepend) {
+      var first = el.childNodes[0];
+      el.insertBefore(child, first);
+    } else {
+      el.appendChild(child);
+    }
+  }
+
+  function insertContent(parent, child, prepend) {
+    var str = isString(child);
+
+    if (!str && child.length) {
+      each(child, function (v) {
+        return insertContent(parent, v, prepend);
+      });
+      return;
+    }
+
+    each(parent, str ? function (v) {
+      return v.insertAdjacentHTML(prepend ? "afterbegin" : "beforeend", child);
+    } : function (v, i) {
+      return insertElement(v, i === 0 ? child : child.cloneNode(true), prepend);
+    });
+  }
+
+  fn.extend({
+    after: function (selector) {
+      cash(selector).insertAfter(this);
+      return this;
+    },
+
+    append: function (content) {
+      insertContent(this, content);
+      return this;
+    },
+
+    appendTo: function (parent) {
+      insertContent(cash(parent), this);
+      return this;
+    },
+
+    before: function (selector) {
+      cash(selector).insertBefore(this);
+      return this;
+    },
+
+    clone: function () {
+      return cash(this.map(function (v) {
+        return v.cloneNode(true);
+      }));
+    },
+
+    empty: function () {
+      this.html("");
+      return this;
+    },
+
+    html: function (content) {
+      if (content === undefined) {
+        return this[0].innerHTML;
+      }
+      var source = content.nodeType ? content[0].outerHTML : content;
+      return this.each(function (v) {
+        return v.innerHTML = source;
+      });
+    },
+
+    insertAfter: function (selector) {
+      var _this = this;
+
+      cash(selector).each(function (el, i) {
+        var parent = el.parentNode,
+            sibling = el.nextSibling;
+        _this.each(function (v) {
+          parent.insertBefore(i === 0 ? v : v.cloneNode(true), sibling);
+        });
+      });
+
+      return this;
+    },
+
+    insertBefore: function (selector) {
+      var _this2 = this;
+      cash(selector).each(function (el, i) {
+        var parent = el.parentNode;
+        _this2.each(function (v) {
+          parent.insertBefore(i === 0 ? v : v.cloneNode(true), el);
+        });
+      });
+      return this;
+    },
+
+    prepend: function (content) {
+      insertContent(this, content, true);
+      return this;
+    },
+
+    prependTo: function (parent) {
+      insertContent(cash(parent), this, true);
+      return this;
+    },
+
+    remove: function () {
+      return this.each(function (v) {
+        if (!!v.parentNode) {
+          return v.parentNode.removeChild(v);
+        }
+      });
+    },
+
+    text: function (content) {
+      if (content === undefined) {
+        return this[0].textContent;
+      }
+      return this.each(function (v) {
+        return v.textContent = content;
+      });
+    }
+
+  });
+
+  var docEl = doc.documentElement;
+
+  fn.extend({
+    position: function () {
+      var el = this[0];
+      return {
+        left: el.offsetLeft,
+        top: el.offsetTop
+      };
+    },
+
+    offset: function () {
+      var rect = this[0].getBoundingClientRect();
+      return {
+        top: rect.top + win.pageYOffset - docEl.clientTop,
+        left: rect.left + win.pageXOffset - docEl.clientLeft
+      };
+    },
+
+    offsetParent: function () {
+      return cash(this[0].offsetParent);
+    }
+
+  });
+
+  fn.extend({
+    children: function (selector) {
+      var elems = [];
+      this.each(function (el) {
+        push.apply(elems, el.children);
+      });
+      elems = unique(elems);
+
+      return !selector ? elems : elems.filter(function (v) {
+        return matches(v, selector);
+      });
+    },
+
+    closest: function (selector) {
+      if (!selector || this.length < 1) {
+        return cash();
+      }
+      if (this.is(selector)) {
+        return this.filter(selector);
+      }
+      return this.parent().closest(selector);
+    },
+
+    is: function (selector) {
+      if (!selector) {
+        return false;
+      }
+
+      var match = false,
+          comparator = getCompareFunction(selector);
+
+      this.each(function (el) {
+        match = comparator(el, selector);
+        return !match;
+      });
+
+      return match;
+    },
+
+    find: function (selector) {
+      if (!selector || selector.nodeType) {
+        return cash(selector && this.has(selector).length ? selector : null);
+      }
+
+      var elems = [];
+      this.each(function (el) {
+        push.apply(elems, find(selector, el));
+      });
+
+      return unique(elems);
+    },
+
+    has: function (selector) {
+      var comparator = isString(selector) ? function (el) {
+        return find(selector, el).length !== 0;
+      } : function (el) {
+        return el.contains(selector);
+      };
+
+      return this.filter(comparator);
+    },
+
+    next: function () {
+      return cash(this[0].nextElementSibling);
+    },
+
+    not: function (selector) {
+      if (!selector) {
+        return this;
+      }
+
+      var comparator = getCompareFunction(selector);
+
+      return this.filter(function (el) {
+        return !comparator(el, selector);
+      });
+    },
+
+    parent: function () {
+      var result = [];
+
+      this.each(function (item) {
+        if (item && item.parentNode) {
+          result.push(item.parentNode);
+        }
+      });
+
+      return unique(result);
+    },
+
+    parents: function (selector) {
+      var last,
+          result = [];
+
+      this.each(function (item) {
+        last = item;
+
+        while (last && last.parentNode && last !== doc.body.parentNode) {
+          last = last.parentNode;
+
+          if (!selector || selector && matches(last, selector)) {
+            result.push(last);
+          }
+        }
+      });
+
+      return unique(result);
+    },
+
+    prev: function () {
+      return cash(this[0].previousElementSibling);
+    },
+
+    siblings: function (selector) {
+      var collection = this.parent().children(selector),
+          el = this[0];
+
+      return collection.filter(function (i) {
+        return i !== el;
+      });
+    }
+
+  });
+
+  return cash;
+});
+;
+var Component = function () {
+  /**
+   * Generic constructor for all components
+   * @constructor
+   * @param {Element} el
+   * @param {Object} options
+   */
+  function Component(classDef, el, options) {
+    _classCallCheck(this, Component);
+
+    // Display error if el is valid HTML Element
+    if (!(el instanceof Element)) {
+      console.error(Error(el + ' is not an HTML Element'));
+    }
+
+    // If exists, destroy and reinitialize in child
+    var ins = classDef.getInstance(el);
+    if (!!ins) {
+      ins.destroy();
+    }
+
+    this.el = el;
+    this.$el = cash(el);
+  }
+
+  /**
+   * Initializes components
+   * @param {class} classDef
+   * @param {Element | NodeList | jQuery} els
+   * @param {Object} options
+   */
+
+
+  _createClass(Component, null, [{
+    key: "init",
+    value: function init(classDef, els, options) {
+      var instances = null;
+      if (els instanceof Element) {
+        instances = new classDef(els, options);
+      } else if (!!els && (els.jquery || els.cash || els instanceof NodeList)) {
+        var instancesArr = [];
+        for (var i = 0; i < els.length; i++) {
+          instancesArr.push(new classDef(els[i], options));
+        }
+        instances = instancesArr;
+      }
+
+      return instances;
+    }
+  }]);
+
+  return Component;
+}();
+
+; // Required for Meteor package, the use of window prevents export by Meteor
+(function (window) {
+  if (window.Package) {
+    M = {};
+  } else {
+    window.M = {};
+  }
+
+  // Check for jQuery
+  M.jQueryLoaded = !!window.jQuery;
+})(window);
+
+// AMD
+if (typeof define === 'function' && define.amd) {
+  define('M', [], function () {
+    return M;
+  });
+
+  // Common JS
+} else if (typeof exports !== 'undefined' && !exports.nodeType) {
+  if (typeof module !== 'undefined' && !module.nodeType && module.exports) {
+    exports = module.exports = M;
+  }
+  exports.default = M;
+}
+
+M.version = '1.0.0';
+
+M.keys = {
+  TAB: 9,
+  ENTER: 13,
+  ESC: 27,
+  ARROW_UP: 38,
+  ARROW_DOWN: 40
+};
+
+/**
+ * TabPress Keydown handler
+ */
+M.tabPressed = false;
+M.keyDown = false;
+var docHandleKeydown = function (e) {
+  M.keyDown = true;
+  if (e.which === M.keys.TAB || e.which === M.keys.ARROW_DOWN || e.which === M.keys.ARROW_UP) {
+    M.tabPressed = true;
+  }
+};
+var docHandleKeyup = function (e) {
+  M.keyDown = false;
+  if (e.which === M.keys.TAB || e.which === M.keys.ARROW_DOWN || e.which === M.keys.ARROW_UP) {
+    M.tabPressed = false;
+  }
+};
+var docHandleFocus = function (e) {
+  if (M.keyDown) {
+    document.body.classList.add('keyboard-focused');
+  }
+};
+var docHandleBlur = function (e) {
+  document.body.classList.remove('keyboard-focused');
+};
+document.addEventListener('keydown', docHandleKeydown, true);
+document.addEventListener('keyup', docHandleKeyup, true);
+document.addEventListener('focus', docHandleFocus, true);
+document.addEventListener('blur', docHandleBlur, true);
+
+/**
+ * Initialize jQuery wrapper for plugin
+ * @param {Class} plugin  javascript class
+ * @param {string} pluginName  jQuery plugin name
+ * @param {string} classRef  Class reference name
+ */
+M.initializeJqueryWrapper = function (plugin, pluginName, classRef) {
+  jQuery.fn[pluginName] = function (methodOrOptions) {
+    // Call plugin method if valid method name is passed in
+    if (plugin.prototype[methodOrOptions]) {
+      var params = Array.prototype.slice.call(arguments, 1);
+
+      // Getter methods
+      if (methodOrOptions.slice(0, 3) === 'get') {
+        var instance = this.first()[0][classRef];
+        return instance[methodOrOptions].apply(instance, params);
+      }
+
+      // Void methods
+      return this.each(function () {
+        var instance = this[classRef];
+        instance[methodOrOptions].apply(instance, params);
+      });
+
+      // Initialize plugin if options or no argument is passed in
+    } else if (typeof methodOrOptions === 'object' || !methodOrOptions) {
+      plugin.init(this, arguments[0]);
+      return this;
+    }
+
+    // Return error if an unrecognized  method name is passed in
+    jQuery.error("Method " + methodOrOptions + " does not exist on jQuery." + pluginName);
+  };
+};
+
+/**
+ * Automatically initialize components
+ * @param {Element} context  DOM Element to search within for components
+ */
+M.AutoInit = function (context) {
+  // Use document.body if no context is given
+  var root = !!context ? context : document.body;
+
+  var registry = {
+    Autocomplete: root.querySelectorAll('.autocomplete:not(.no-autoinit)'),
+    Carousel: root.querySelectorAll('.carousel:not(.no-autoinit)'),
+    Chips: root.querySelectorAll('.chips:not(.no-autoinit)'),
+    Collapsible: root.querySelectorAll('.collapsible:not(.no-autoinit)'),
+    Datepicker: root.querySelectorAll('.datepicker:not(.no-autoinit)'),
+    Dropdown: root.querySelectorAll('.dropdown-trigger:not(.no-autoinit)'),
+    Materialbox: root.querySelectorAll('.materialboxed:not(.no-autoinit)'),
+    Modal: root.querySelectorAll('.modal:not(.no-autoinit)'),
+    Parallax: root.querySelectorAll('.parallax:not(.no-autoinit)'),
+    Pushpin: root.querySelectorAll('.pushpin:not(.no-autoinit)'),
+    ScrollSpy: root.querySelectorAll('.scrollspy:not(.no-autoinit)'),
+    FormSelect: root.querySelectorAll('select:not(.no-autoinit)'),
+    Sidenav: root.querySelectorAll('.sidenav:not(.no-autoinit)'),
+    Tabs: root.querySelectorAll('.tabs:not(.no-autoinit)'),
+    TapTarget: root.querySelectorAll('.tap-target:not(.no-autoinit)'),
+    Timepicker: root.querySelectorAll('.timepicker:not(.no-autoinit)'),
+    Tooltip: root.querySelectorAll('.tooltipped:not(.no-autoinit)'),
+    FloatingActionButton: root.querySelectorAll('.fixed-action-btn:not(.no-autoinit)')
+  };
+
+  for (var pluginName in registry) {
+    var plugin = M[pluginName];
+    plugin.init(registry[pluginName]);
+  }
+};
+
+/**
+ * Generate approximated selector string for a jQuery object
+ * @param {jQuery} obj  jQuery object to be parsed
+ * @returns {string}
+ */
+M.objectSelectorString = function (obj) {
+  var tagStr = obj.prop('tagName') || '';
+  var idStr = obj.attr('id') || '';
+  var classStr = obj.attr('class') || '';
+  return (tagStr + idStr + classStr).replace(/\s/g, '');
+};
+
+// Unique Random ID
+M.guid = function () {
+  function s4() {
+    return Math.floor((1 + Math.random()) * 0x10000).toString(16).substring(1);
+  }
+  return function () {
+    return s4() + s4() + '-' + s4() + '-' + s4() + '-' + s4() + '-' + s4() + s4() + s4();
+  };
+}();
+
+/**
+ * Escapes hash from special characters
+ * @param {string} hash  String returned from this.hash
+ * @returns {string}
+ */
+M.escapeHash = function (hash) {
+  return hash.replace(/(:|\.|\[|\]|,|=|\/)/g, '\\$1');
+};
+
+M.elementOrParentIsFixed = function (element) {
+  var $element = $(element);
+  var $checkElements = $element.add($element.parents());
+  var isFixed = false;
+  $checkElements.each(function () {
+    if ($(this).css('position') === 'fixed') {
+      isFixed = true;
+      return false;
+    }
+  });
+  return isFixed;
+};
+
+/**
+ * @typedef {Object} Edges
+ * @property {Boolean} top  If the top edge was exceeded
+ * @property {Boolean} right  If the right edge was exceeded
+ * @property {Boolean} bottom  If the bottom edge was exceeded
+ * @property {Boolean} left  If the left edge was exceeded
+ */
+
+/**
+ * @typedef {Object} Bounding
+ * @property {Number} left  left offset coordinate
+ * @property {Number} top  top offset coordinate
+ * @property {Number} width
+ * @property {Number} height
+ */
+
+/**
+ * Escapes hash from special characters
+ * @param {Element} container  Container element that acts as the boundary
+ * @param {Bounding} bounding  element bounding that is being checked
+ * @param {Number} offset  offset from edge that counts as exceeding
+ * @returns {Edges}
+ */
+M.checkWithinContainer = function (container, bounding, offset) {
+  var edges = {
+    top: false,
+    right: false,
+    bottom: false,
+    left: false
+  };
+
+  var containerRect = container.getBoundingClientRect();
+  // If body element is smaller than viewport, use viewport height instead.
+  var containerBottom = container === document.body ? Math.max(containerRect.bottom, window.innerHeight) : containerRect.bottom;
+
+  var scrollLeft = container.scrollLeft;
+  var scrollTop = container.scrollTop;
+
+  var scrolledX = bounding.left - scrollLeft;
+  var scrolledY = bounding.top - scrollTop;
+
+  // Check for container and viewport for each edge
+  if (scrolledX < containerRect.left + offset || scrolledX < offset) {
+    edges.left = true;
+  }
+
+  if (scrolledX + bounding.width > containerRect.right - offset || scrolledX + bounding.width > window.innerWidth - offset) {
+    edges.right = true;
+  }
+
+  if (scrolledY < containerRect.top + offset || scrolledY < offset) {
+    edges.top = true;
+  }
+
+  if (scrolledY + bounding.height > containerBottom - offset || scrolledY + bounding.height > window.innerHeight - offset) {
+    edges.bottom = true;
+  }
+
+  return edges;
+};
+
+M.checkPossibleAlignments = function (el, container, bounding, offset) {
+  var canAlign = {
+    top: true,
+    right: true,
+    bottom: true,
+    left: true,
+    spaceOnTop: null,
+    spaceOnRight: null,
+    spaceOnBottom: null,
+    spaceOnLeft: null
+  };
+
+  var containerAllowsOverflow = getComputedStyle(container).overflow === 'visible';
+  var containerRect = container.getBoundingClientRect();
+  var containerHeight = Math.min(containerRect.height, window.innerHeight);
+  var containerWidth = Math.min(containerRect.width, window.innerWidth);
+  var elOffsetRect = el.getBoundingClientRect();
+
+  var scrollLeft = container.scrollLeft;
+  var scrollTop = container.scrollTop;
+
+  var scrolledX = bounding.left - scrollLeft;
+  var scrolledYTopEdge = bounding.top - scrollTop;
+  var scrolledYBottomEdge = bounding.top + elOffsetRect.height - scrollTop;
+
+  // Check for container and viewport for left
+  canAlign.spaceOnRight = !containerAllowsOverflow ? containerWidth - (scrolledX + bounding.width) : window.innerWidth - (elOffsetRect.left + bounding.width);
+  if (canAlign.spaceOnRight < 0) {
+    canAlign.left = false;
+  }
+
+  // Check for container and viewport for Right
+  canAlign.spaceOnLeft = !containerAllowsOverflow ? scrolledX - bounding.width + elOffsetRect.width : elOffsetRect.right - bounding.width;
+  if (canAlign.spaceOnLeft < 0) {
+    canAlign.right = false;
+  }
+
+  // Check for container and viewport for Top
+  canAlign.spaceOnBottom = !containerAllowsOverflow ? containerHeight - (scrolledYTopEdge + bounding.height + offset) : window.innerHeight - (elOffsetRect.top + bounding.height + offset);
+  if (canAlign.spaceOnBottom < 0) {
+    canAlign.top = false;
+  }
+
+  // Check for container and viewport for Bottom
+  canAlign.spaceOnTop = !containerAllowsOverflow ? scrolledYBottomEdge - (bounding.height - offset) : elOffsetRect.bottom - (bounding.height + offset);
+  if (canAlign.spaceOnTop < 0) {
+    canAlign.bottom = false;
+  }
+
+  return canAlign;
+};
+
+M.getOverflowParent = function (element) {
+  if (element == null) {
+    return null;
+  }
+
+  if (element === document.body || getComputedStyle(element).overflow !== 'visible') {
+    return element;
+  }
+
+  return M.getOverflowParent(element.parentElement);
+};
+
+/**
+ * Gets id of component from a trigger
+ * @param {Element} trigger  trigger
+ * @returns {string}
+ */
+M.getIdFromTrigger = function (trigger) {
+  var id = trigger.getAttribute('data-target');
+  if (!id) {
+    id = trigger.getAttribute('href');
+    if (id) {
+      id = id.slice(1);
+    } else {
+      id = '';
+    }
+  }
+  return id;
+};
+
+/**
+ * Multi browser support for document scroll top
+ * @returns {Number}
+ */
+M.getDocumentScrollTop = function () {
+  return window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0;
+};
+
+/**
+ * Multi browser support for document scroll left
+ * @returns {Number}
+ */
+M.getDocumentScrollLeft = function () {
+  return window.pageXOffset || document.documentElement.scrollLeft || document.body.scrollLeft || 0;
+};
+
+/**
+ * @typedef {Object} Edges
+ * @property {Boolean} top  If the top edge was exceeded
+ * @property {Boolean} right  If the right edge was exceeded
+ * @property {Boolean} bottom  If the bottom edge was exceeded
+ * @property {Boolean} left  If the left edge was exceeded
+ */
+
+/**
+ * @typedef {Object} Bounding
+ * @property {Number} left  left offset coordinate
+ * @property {Number} top  top offset coordinate
+ * @property {Number} width
+ * @property {Number} height
+ */
+
+/**
+ * Get time in ms
+ * @license https://raw.github.com/jashkenas/underscore/master/LICENSE
+ * @type {function}
+ * @return {number}
+ */
+var getTime = Date.now || function () {
+  return new Date().getTime();
+};
+
+/**
+ * Returns a function, that, when invoked, will only be triggered at most once
+ * during a given window of time. Normally, the throttled function will run
+ * as much as it can, without ever going more than once per `wait` duration;
+ * but if you'd like to disable the execution on the leading edge, pass
+ * `{leading: false}`. To disable execution on the trailing edge, ditto.
+ * @license https://raw.github.com/jashkenas/underscore/master/LICENSE
+ * @param {function} func
+ * @param {number} wait
+ * @param {Object=} options
+ * @returns {Function}
+ */
+M.throttle = function (func, wait, options) {
+  var context = void 0,
+      args = void 0,
+      result = void 0;
+  var timeout = null;
+  var previous = 0;
+  options || (options = {});
+  var later = function () {
+    previous = options.leading === false ? 0 : getTime();
+    timeout = null;
+    result = func.apply(context, args);
+    context = args = null;
+  };
+  return function () {
+    var now = getTime();
+    if (!previous && options.leading === false) previous = now;
+    var remaining = wait - (now - previous);
+    context = this;
+    args = arguments;
+    if (remaining <= 0) {
+      clearTimeout(timeout);
+      timeout = null;
+      previous = now;
+      result = func.apply(context, args);
+      context = args = null;
+    } else if (!timeout && options.trailing !== false) {
+      timeout = setTimeout(later, remaining);
+    }
+    return result;
+  };
+};
+; /*
+  v2.2.0
+  2017 Julian Garnier
+  Released under the MIT license
+  */
+var $jscomp = { scope: {} };$jscomp.defineProperty = "function" == typeof Object.defineProperties ? Object.defineProperty : function (e, r, p) {
+  if (p.get || p.set) throw new TypeError("ES3 does not support getters and setters.");e != Array.prototype && e != Object.prototype && (e[r] = p.value);
+};$jscomp.getGlobal = function (e) {
+  return "undefined" != typeof window && window === e ? e : "undefined" != typeof global && null != global ? global : e;
+};$jscomp.global = $jscomp.getGlobal(this);$jscomp.SYMBOL_PREFIX = "jscomp_symbol_";
+$jscomp.initSymbol = function () {
+  $jscomp.initSymbol = function () {};$jscomp.global.Symbol || ($jscomp.global.Symbol = $jscomp.Symbol);
+};$jscomp.symbolCounter_ = 0;$jscomp.Symbol = function (e) {
+  return $jscomp.SYMBOL_PREFIX + (e || "") + $jscomp.symbolCounter_++;
+};
+$jscomp.initSymbolIterator = function () {
+  $jscomp.initSymbol();var e = $jscomp.global.Symbol.iterator;e || (e = $jscomp.global.Symbol.iterator = $jscomp.global.Symbol("iterator"));"function" != typeof Array.prototype[e] && $jscomp.defineProperty(Array.prototype, e, { configurable: !0, writable: !0, value: function () {
+      return $jscomp.arrayIterator(this);
+    } });$jscomp.initSymbolIterator = function () {};
+};$jscomp.arrayIterator = function (e) {
+  var r = 0;return $jscomp.iteratorPrototype(function () {
+    return r < e.length ? { done: !1, value: e[r++] } : { done: !0 };
+  });
+};
+$jscomp.iteratorPrototype = function (e) {
+  $jscomp.initSymbolIterator();e = { next: e };e[$jscomp.global.Symbol.iterator] = function () {
+    return this;
+  };return e;
+};$jscomp.array = $jscomp.array || {};$jscomp.iteratorFromArray = function (e, r) {
+  $jscomp.initSymbolIterator();e instanceof String && (e += "");var p = 0,
+      m = { next: function () {
+      if (p < e.length) {
+        var u = p++;return { value: r(u, e[u]), done: !1 };
+      }m.next = function () {
+        return { done: !0, value: void 0 };
+      };return m.next();
+    } };m[Symbol.iterator] = function () {
+    return m;
+  };return m;
+};
+$jscomp.polyfill = function (e, r, p, m) {
+  if (r) {
+    p = $jscomp.global;e = e.split(".");for (m = 0; m < e.length - 1; m++) {
+      var u = e[m];u in p || (p[u] = {});p = p[u];
+    }e = e[e.length - 1];m = p[e];r = r(m);r != m && null != r && $jscomp.defineProperty(p, e, { configurable: !0, writable: !0, value: r });
+  }
+};$jscomp.polyfill("Array.prototype.keys", function (e) {
+  return e ? e : function () {
+    return $jscomp.iteratorFromArray(this, function (e) {
+      return e;
+    });
+  };
+}, "es6-impl", "es3");var $jscomp$this = this;
+(function (r) {
+  M.anime = r();
+})(function () {
+  function e(a) {
+    if (!h.col(a)) try {
+      return document.querySelectorAll(a);
+    } catch (c) {}
+  }function r(a, c) {
+    for (var d = a.length, b = 2 <= arguments.length ? arguments[1] : void 0, f = [], n = 0; n < d; n++) {
+      if (n in a) {
+        var k = a[n];c.call(b, k, n, a) && f.push(k);
+      }
+    }return f;
+  }function p(a) {
+    return a.reduce(function (a, d) {
+      return a.concat(h.arr(d) ? p(d) : d);
+    }, []);
+  }function m(a) {
+    if (h.arr(a)) return a;
+    h.str(a) && (a = e(a) || a);return a instanceof NodeList || a instanceof HTMLCollection ? [].slice.call(a) : [a];
+  }function u(a, c) {
+    return a.some(function (a) {
+      return a === c;
+    });
+  }function C(a) {
+    var c = {},
+        d;for (d in a) {
+      c[d] = a[d];
+    }return c;
+  }function D(a, c) {
+    var d = C(a),
+        b;for (b in a) {
+      d[b] = c.hasOwnProperty(b) ? c[b] : a[b];
+    }return d;
+  }function z(a, c) {
+    var d = C(a),
+        b;for (b in c) {
+      d[b] = h.und(a[b]) ? c[b] : a[b];
+    }return d;
+  }function T(a) {
+    a = a.replace(/^#?([a-f\d])([a-f\d])([a-f\d])$/i, function (a, c, d, k) {
+      return c + c + d + d + k + k;
+    });var c = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(a);
+    a = parseInt(c[1], 16);var d = parseInt(c[2], 16),
+        c = parseInt(c[3], 16);return "rgba(" + a + "," + d + "," + c + ",1)";
+  }function U(a) {
+    function c(a, c, b) {
+      0 > b && (b += 1);1 < b && --b;return b < 1 / 6 ? a + 6 * (c - a) * b : .5 > b ? c : b < 2 / 3 ? a + (c - a) * (2 / 3 - b) * 6 : a;
+    }var d = /hsl\((\d+),\s*([\d.]+)%,\s*([\d.]+)%\)/g.exec(a) || /hsla\((\d+),\s*([\d.]+)%,\s*([\d.]+)%,\s*([\d.]+)\)/g.exec(a);a = parseInt(d[1]) / 360;var b = parseInt(d[2]) / 100,
+        f = parseInt(d[3]) / 100,
+        d = d[4] || 1;if (0 == b) f = b = a = f;else {
+      var n = .5 > f ? f * (1 + b) : f + b - f * b,
+          k = 2 * f - n,
+          f = c(k, n, a + 1 / 3),
+          b = c(k, n, a);a = c(k, n, a - 1 / 3);
+    }return "rgba(" + 255 * f + "," + 255 * b + "," + 255 * a + "," + d + ")";
+  }function y(a) {
+    if (a = /([\+\-]?[0-9#\.]+)(%|px|pt|em|rem|in|cm|mm|ex|ch|pc|vw|vh|vmin|vmax|deg|rad|turn)?$/.exec(a)) return a[2];
+  }function V(a) {
+    if (-1 < a.indexOf("translate") || "perspective" === a) return "px";if (-1 < a.indexOf("rotate") || -1 < a.indexOf("skew")) return "deg";
+  }function I(a, c) {
+    return h.fnc(a) ? a(c.target, c.id, c.total) : a;
+  }function E(a, c) {
+    if (c in a.style) return getComputedStyle(a).getPropertyValue(c.replace(/([a-z])([A-Z])/g, "$1-$2").toLowerCase()) || "0";
+  }function J(a, c) {
+    if (h.dom(a) && u(W, c)) return "transform";if (h.dom(a) && (a.getAttribute(c) || h.svg(a) && a[c])) return "attribute";if (h.dom(a) && "transform" !== c && E(a, c)) return "css";if (null != a[c]) return "object";
+  }function X(a, c) {
+    var d = V(c),
+        d = -1 < c.indexOf("scale") ? 1 : 0 + d;a = a.style.transform;if (!a) return d;for (var b = [], f = [], n = [], k = /(\w+)\((.+?)\)/g; b = k.exec(a);) {
+      f.push(b[1]), n.push(b[2]);
+    }a = r(n, function (a, b) {
+      return f[b] === c;
+    });return a.length ? a[0] : d;
+  }function K(a, c) {
+    switch (J(a, c)) {case "transform":
+        return X(a, c);case "css":
+        return E(a, c);case "attribute":
+        return a.getAttribute(c);}return a[c] || 0;
+  }function L(a, c) {
+    var d = /^(\*=|\+=|-=)/.exec(a);if (!d) return a;var b = y(a) || 0;c = parseFloat(c);a = parseFloat(a.replace(d[0], ""));switch (d[0][0]) {case "+":
+        return c + a + b;case "-":
+        return c - a + b;case "*":
+        return c * a + b;}
+  }function F(a, c) {
+    return Math.sqrt(Math.pow(c.x - a.x, 2) + Math.pow(c.y - a.y, 2));
+  }function M(a) {
+    a = a.points;for (var c = 0, d, b = 0; b < a.numberOfItems; b++) {
+      var f = a.getItem(b);0 < b && (c += F(d, f));d = f;
+    }return c;
+  }function N(a) {
+    if (a.getTotalLength) return a.getTotalLength();switch (a.tagName.toLowerCase()) {case "circle":
+        return 2 * Math.PI * a.getAttribute("r");case "rect":
+        return 2 * a.getAttribute("width") + 2 * a.getAttribute("height");case "line":
+        return F({ x: a.getAttribute("x1"), y: a.getAttribute("y1") }, { x: a.getAttribute("x2"), y: a.getAttribute("y2") });case "polyline":
+        return M(a);case "polygon":
+        var c = a.points;return M(a) + F(c.getItem(c.numberOfItems - 1), c.getItem(0));}
+  }function Y(a, c) {
+    function d(b) {
+      b = void 0 === b ? 0 : b;return a.el.getPointAtLength(1 <= c + b ? c + b : 0);
+    }var b = d(),
+        f = d(-1),
+        n = d(1);switch (a.property) {case "x":
+        return b.x;case "y":
+        return b.y;
+      case "angle":
+        return 180 * Math.atan2(n.y - f.y, n.x - f.x) / Math.PI;}
+  }function O(a, c) {
+    var d = /-?\d*\.?\d+/g,
+        b;b = h.pth(a) ? a.totalLength : a;if (h.col(b)) {
+      if (h.rgb(b)) {
+        var f = /rgb\((\d+,\s*[\d]+,\s*[\d]+)\)/g.exec(b);b = f ? "rgba(" + f[1] + ",1)" : b;
+      } else b = h.hex(b) ? T(b) : h.hsl(b) ? U(b) : void 0;
+    } else f = (f = y(b)) ? b.substr(0, b.length - f.length) : b, b = c && !/\s/g.test(b) ? f + c : f;b += "";return { original: b, numbers: b.match(d) ? b.match(d).map(Number) : [0], strings: h.str(a) || c ? b.split(d) : [] };
+  }function P(a) {
+    a = a ? p(h.arr(a) ? a.map(m) : m(a)) : [];return r(a, function (a, d, b) {
+      return b.indexOf(a) === d;
+    });
+  }function Z(a) {
+    var c = P(a);return c.map(function (a, b) {
+      return { target: a, id: b, total: c.length };
+    });
+  }function aa(a, c) {
+    var d = C(c);if (h.arr(a)) {
+      var b = a.length;2 !== b || h.obj(a[0]) ? h.fnc(c.duration) || (d.duration = c.duration / b) : a = { value: a };
+    }return m(a).map(function (a, b) {
+      b = b ? 0 : c.delay;a = h.obj(a) && !h.pth(a) ? a : { value: a };h.und(a.delay) && (a.delay = b);return a;
+    }).map(function (a) {
+      return z(a, d);
+    });
+  }function ba(a, c) {
+    var d = {},
+        b;for (b in a) {
+      var f = I(a[b], c);h.arr(f) && (f = f.map(function (a) {
+        return I(a, c);
+      }), 1 === f.length && (f = f[0]));d[b] = f;
+    }d.duration = parseFloat(d.duration);d.delay = parseFloat(d.delay);return d;
+  }function ca(a) {
+    return h.arr(a) ? A.apply(this, a) : Q[a];
+  }function da(a, c) {
+    var d;return a.tweens.map(function (b) {
+      b = ba(b, c);var f = b.value,
+          e = K(c.target, a.name),
+          k = d ? d.to.original : e,
+          k = h.arr(f) ? f[0] : k,
+          w = L(h.arr(f) ? f[1] : f, k),
+          e = y(w) || y(k) || y(e);b.from = O(k, e);b.to = O(w, e);b.start = d ? d.end : a.offset;b.end = b.start + b.delay + b.duration;b.easing = ca(b.easing);b.elasticity = (1E3 - Math.min(Math.max(b.elasticity, 1), 999)) / 1E3;b.isPath = h.pth(f);b.isColor = h.col(b.from.original);b.isColor && (b.round = 1);return d = b;
+    });
+  }function ea(a, c) {
+    return r(p(a.map(function (a) {
+      return c.map(function (b) {
+        var c = J(a.target, b.name);if (c) {
+          var d = da(b, a);b = { type: c, property: b.name, animatable: a, tweens: d, duration: d[d.length - 1].end, delay: d[0].delay };
+        } else b = void 0;return b;
+      });
+    })), function (a) {
+      return !h.und(a);
+    });
+  }function R(a, c, d, b) {
+    var f = "delay" === a;return c.length ? (f ? Math.min : Math.max).apply(Math, c.map(function (b) {
+      return b[a];
+    })) : f ? b.delay : d.offset + b.delay + b.duration;
+  }function fa(a) {
+    var c = D(ga, a),
+        d = D(S, a),
+        b = Z(a.targets),
+        f = [],
+        e = z(c, d),
+        k;for (k in a) {
+      e.hasOwnProperty(k) || "targets" === k || f.push({ name: k, offset: e.offset, tweens: aa(a[k], d) });
+    }a = ea(b, f);return z(c, { children: [], animatables: b, animations: a, duration: R("duration", a, c, d), delay: R("delay", a, c, d) });
+  }function q(a) {
+    function c() {
+      return window.Promise && new Promise(function (a) {
+        return p = a;
+      });
+    }function d(a) {
+      return g.reversed ? g.duration - a : a;
+    }function b(a) {
+      for (var b = 0, c = {}, d = g.animations, f = d.length; b < f;) {
+        var e = d[b],
+            k = e.animatable,
+            h = e.tweens,
+            n = h.length - 1,
+            l = h[n];n && (l = r(h, function (b) {
+          return a < b.end;
+        })[0] || l);for (var h = Math.min(Math.max(a - l.start - l.delay, 0), l.duration) / l.duration, w = isNaN(h) ? 1 : l.easing(h, l.elasticity), h = l.to.strings, p = l.round, n = [], m = void 0, m = l.to.numbers.length, t = 0; t < m; t++) {
+          var x = void 0,
+              x = l.to.numbers[t],
+              q = l.from.numbers[t],
+              x = l.isPath ? Y(l.value, w * x) : q + w * (x - q);p && (l.isColor && 2 < t || (x = Math.round(x * p) / p));n.push(x);
+        }if (l = h.length) for (m = h[0], w = 0; w < l; w++) {
+          p = h[w + 1], t = n[w], isNaN(t) || (m = p ? m + (t + p) : m + (t + " "));
+        } else m = n[0];ha[e.type](k.target, e.property, m, c, k.id);e.currentValue = m;b++;
+      }if (b = Object.keys(c).length) for (d = 0; d < b; d++) {
+        H || (H = E(document.body, "transform") ? "transform" : "-webkit-transform"), g.animatables[d].target.style[H] = c[d].join(" ");
+      }g.currentTime = a;g.progress = a / g.duration * 100;
+    }function f(a) {
+      if (g[a]) g[a](g);
+    }function e() {
+      g.remaining && !0 !== g.remaining && g.remaining--;
+    }function k(a) {
+      var k = g.duration,
+          n = g.offset,
+          w = n + g.delay,
+          r = g.currentTime,
+          x = g.reversed,
+          q = d(a);if (g.children.length) {
+        var u = g.children,
+            v = u.length;
+        if (q >= g.currentTime) for (var G = 0; G < v; G++) {
+          u[G].seek(q);
+        } else for (; v--;) {
+          u[v].seek(q);
+        }
+      }if (q >= w || !k) g.began || (g.began = !0, f("begin")), f("run");if (q > n && q < k) b(q);else if (q <= n && 0 !== r && (b(0), x && e()), q >= k && r !== k || !k) b(k), x || e();f("update");a >= k && (g.remaining ? (t = h, "alternate" === g.direction && (g.reversed = !g.reversed)) : (g.pause(), g.completed || (g.completed = !0, f("complete"), "Promise" in window && (p(), m = c()))), l = 0);
+    }a = void 0 === a ? {} : a;var h,
+        t,
+        l = 0,
+        p = null,
+        m = c(),
+        g = fa(a);g.reset = function () {
+      var a = g.direction,
+          c = g.loop;g.currentTime = 0;g.progress = 0;g.paused = !0;g.began = !1;g.completed = !1;g.reversed = "reverse" === a;g.remaining = "alternate" === a && 1 === c ? 2 : c;b(0);for (a = g.children.length; a--;) {
+        g.children[a].reset();
+      }
+    };g.tick = function (a) {
+      h = a;t || (t = h);k((l + h - t) * q.speed);
+    };g.seek = function (a) {
+      k(d(a));
+    };g.pause = function () {
+      var a = v.indexOf(g);-1 < a && v.splice(a, 1);g.paused = !0;
+    };g.play = function () {
+      g.paused && (g.paused = !1, t = 0, l = d(g.currentTime), v.push(g), B || ia());
+    };g.reverse = function () {
+      g.reversed = !g.reversed;t = 0;l = d(g.currentTime);
+    };g.restart = function () {
+      g.pause();
+      g.reset();g.play();
+    };g.finished = m;g.reset();g.autoplay && g.play();return g;
+  }var ga = { update: void 0, begin: void 0, run: void 0, complete: void 0, loop: 1, direction: "normal", autoplay: !0, offset: 0 },
+      S = { duration: 1E3, delay: 0, easing: "easeOutElastic", elasticity: 500, round: 0 },
+      W = "translateX translateY translateZ rotate rotateX rotateY rotateZ scale scaleX scaleY scaleZ skewX skewY perspective".split(" "),
+      H,
+      h = { arr: function (a) {
+      return Array.isArray(a);
+    }, obj: function (a) {
+      return -1 < Object.prototype.toString.call(a).indexOf("Object");
+    },
+    pth: function (a) {
+      return h.obj(a) && a.hasOwnProperty("totalLength");
+    }, svg: function (a) {
+      return a instanceof SVGElement;
+    }, dom: function (a) {
+      return a.nodeType || h.svg(a);
+    }, str: function (a) {
+      return "string" === typeof a;
+    }, fnc: function (a) {
+      return "function" === typeof a;
+    }, und: function (a) {
+      return "undefined" === typeof a;
+    }, hex: function (a) {
+      return (/(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(a)
+      );
+    }, rgb: function (a) {
+      return (/^rgb/.test(a)
+      );
+    }, hsl: function (a) {
+      return (/^hsl/.test(a)
+      );
+    }, col: function (a) {
+      return h.hex(a) || h.rgb(a) || h.hsl(a);
+    } },
+      A = function () {
+    function a(a, d, b) {
+      return (((1 - 3 * b + 3 * d) * a + (3 * b - 6 * d)) * a + 3 * d) * a;
+    }return function (c, d, b, f) {
+      if (0 <= c && 1 >= c && 0 <= b && 1 >= b) {
+        var e = new Float32Array(11);if (c !== d || b !== f) for (var k = 0; 11 > k; ++k) {
+          e[k] = a(.1 * k, c, b);
+        }return function (k) {
+          if (c === d && b === f) return k;if (0 === k) return 0;if (1 === k) return 1;for (var h = 0, l = 1; 10 !== l && e[l] <= k; ++l) {
+            h += .1;
+          }--l;var l = h + (k - e[l]) / (e[l + 1] - e[l]) * .1,
+              n = 3 * (1 - 3 * b + 3 * c) * l * l + 2 * (3 * b - 6 * c) * l + 3 * c;if (.001 <= n) {
+            for (h = 0; 4 > h; ++h) {
+              n = 3 * (1 - 3 * b + 3 * c) * l * l + 2 * (3 * b - 6 * c) * l + 3 * c;if (0 === n) break;var m = a(l, c, b) - k,
+                  l = l - m / n;
+            }k = l;
+          } else if (0 === n) k = l;else {
+            var l = h,
+                h = h + .1,
+                g = 0;do {
+              m = l + (h - l) / 2, n = a(m, c, b) - k, 0 < n ? h = m : l = m;
+            } while (1e-7 < Math.abs(n) && 10 > ++g);k = m;
+          }return a(k, d, f);
+        };
+      }
+    };
+  }(),
+      Q = function () {
+    function a(a, b) {
+      return 0 === a || 1 === a ? a : -Math.pow(2, 10 * (a - 1)) * Math.sin(2 * (a - 1 - b / (2 * Math.PI) * Math.asin(1)) * Math.PI / b);
+    }var c = "Quad Cubic Quart Quint Sine Expo Circ Back Elastic".split(" "),
+        d = { In: [[.55, .085, .68, .53], [.55, .055, .675, .19], [.895, .03, .685, .22], [.755, .05, .855, .06], [.47, 0, .745, .715], [.95, .05, .795, .035], [.6, .04, .98, .335], [.6, -.28, .735, .045], a], Out: [[.25, .46, .45, .94], [.215, .61, .355, 1], [.165, .84, .44, 1], [.23, 1, .32, 1], [.39, .575, .565, 1], [.19, 1, .22, 1], [.075, .82, .165, 1], [.175, .885, .32, 1.275], function (b, c) {
+        return 1 - a(1 - b, c);
+      }], InOut: [[.455, .03, .515, .955], [.645, .045, .355, 1], [.77, 0, .175, 1], [.86, 0, .07, 1], [.445, .05, .55, .95], [1, 0, 0, 1], [.785, .135, .15, .86], [.68, -.55, .265, 1.55], function (b, c) {
+        return .5 > b ? a(2 * b, c) / 2 : 1 - a(-2 * b + 2, c) / 2;
+      }] },
+        b = { linear: A(.25, .25, .75, .75) },
+        f = {},
+        e;for (e in d) {
+      f.type = e, d[f.type].forEach(function (a) {
+        return function (d, f) {
+          b["ease" + a.type + c[f]] = h.fnc(d) ? d : A.apply($jscomp$this, d);
+        };
+      }(f)), f = { type: f.type };
+    }return b;
+  }(),
+      ha = { css: function (a, c, d) {
+      return a.style[c] = d;
+    }, attribute: function (a, c, d) {
+      return a.setAttribute(c, d);
+    }, object: function (a, c, d) {
+      return a[c] = d;
+    }, transform: function (a, c, d, b, f) {
+      b[f] || (b[f] = []);b[f].push(c + "(" + d + ")");
+    } },
+      v = [],
+      B = 0,
+      ia = function () {
+    function a() {
+      B = requestAnimationFrame(c);
+    }function c(c) {
+      var b = v.length;if (b) {
+        for (var d = 0; d < b;) {
+          v[d] && v[d].tick(c), d++;
+        }a();
+      } else cancelAnimationFrame(B), B = 0;
+    }return a;
+  }();q.version = "2.2.0";q.speed = 1;q.running = v;q.remove = function (a) {
+    a = P(a);for (var c = v.length; c--;) {
+      for (var d = v[c], b = d.animations, f = b.length; f--;) {
+        u(a, b[f].animatable.target) && (b.splice(f, 1), b.length || d.pause());
+      }
+    }
+  };q.getValue = K;q.path = function (a, c) {
+    var d = h.str(a) ? e(a)[0] : a,
+        b = c || 100;return function (a) {
+      return { el: d, property: a, totalLength: N(d) * (b / 100) };
+    };
+  };q.setDashoffset = function (a) {
+    var c = N(a);a.setAttribute("stroke-dasharray", c);return c;
+  };q.bezier = A;q.easings = Q;q.timeline = function (a) {
+    var c = q(a);c.pause();c.duration = 0;c.add = function (d) {
+      c.children.forEach(function (a) {
+        a.began = !0;a.completed = !0;
+      });m(d).forEach(function (b) {
+        var d = z(b, D(S, a || {}));d.targets = d.targets || a.targets;b = c.duration;var e = d.offset;d.autoplay = !1;d.direction = c.direction;d.offset = h.und(e) ? b : L(e, b);c.began = !0;c.completed = !0;c.seek(d.offset);d = q(d);d.began = !0;d.completed = !0;d.duration > b && (c.duration = d.duration);c.children.push(d);
+      });c.seek(0);c.reset();c.autoplay && c.restart();return c;
+    };return c;
+  };q.random = function (a, c) {
+    return Math.floor(Math.random() * (c - a + 1)) + a;
+  };return q;
+});
+;(function ($, anim) {
+  'use strict';
+
+  var _defaults = {
+    accordion: true,
+    onOpenStart: undefined,
+    onOpenEnd: undefined,
+    onCloseStart: undefined,
+    onCloseEnd: undefined,
+    inDuration: 300,
+    outDuration: 300
+  };
+
+  /**
+   * @class
+   *
+   */
+
+  var Collapsible = function (_Component) {
+    _inherits(Collapsible, _Component);
+
+    /**
+     * Construct Collapsible instance
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function Collapsible(el, options) {
+      _classCallCheck(this, Collapsible);
+
+      var _this3 = _possibleConstructorReturn(this, (Collapsible.__proto__ || Object.getPrototypeOf(Collapsible)).call(this, Collapsible, el, options));
+
+      _this3.el.M_Collapsible = _this3;
+
+      /**
+       * Options for the collapsible
+       * @member Collapsible#options
+       * @prop {Boolean} [accordion=false] - Type of the collapsible
+       * @prop {Function} onOpenStart - Callback function called before collapsible is opened
+       * @prop {Function} onOpenEnd - Callback function called after collapsible is opened
+       * @prop {Function} onCloseStart - Callback function called before collapsible is closed
+       * @prop {Function} onCloseEnd - Callback function called after collapsible is closed
+       * @prop {Number} inDuration - Transition in duration in milliseconds.
+       * @prop {Number} outDuration - Transition duration in milliseconds.
+       */
+      _this3.options = $.extend({}, Collapsible.defaults, options);
+
+      // Setup tab indices
+      _this3.$headers = _this3.$el.children('li').children('.collapsible-header');
+      _this3.$headers.attr('tabindex', 0);
+
+      _this3._setupEventHandlers();
+
+      // Open first active
+      var $activeBodies = _this3.$el.children('li.active').children('.collapsible-body');
+      if (_this3.options.accordion) {
+        // Handle Accordion
+        $activeBodies.first().css('display', 'block');
+      } else {
+        // Handle Expandables
+        $activeBodies.css('display', 'block');
+      }
+      return _this3;
+    }
+
+    _createClass(Collapsible, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        this._removeEventHandlers();
+        this.el.M_Collapsible = undefined;
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        var _this4 = this;
+
+        this._handleCollapsibleClickBound = this._handleCollapsibleClick.bind(this);
+        this._handleCollapsibleKeydownBound = this._handleCollapsibleKeydown.bind(this);
+        this.el.addEventListener('click', this._handleCollapsibleClickBound);
+        this.$headers.each(function (header) {
+          header.addEventListener('keydown', _this4._handleCollapsibleKeydownBound);
+        });
+      }
+
+      /**
+       * Remove Event Handlers
+       */
+
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        var _this5 = this;
+
+        this.el.removeEventListener('click', this._handleCollapsibleClickBound);
+        this.$headers.each(function (header) {
+          header.removeEventListener('keydown', _this5._handleCollapsibleKeydownBound);
+        });
+      }
+
+      /**
+       * Handle Collapsible Click
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleCollapsibleClick",
+      value: function _handleCollapsibleClick(e) {
+        var $header = $(e.target).closest('.collapsible-header');
+        if (e.target && $header.length) {
+          var $collapsible = $header.closest('.collapsible');
+          if ($collapsible[0] === this.el) {
+            var $collapsibleLi = $header.closest('li');
+            var $collapsibleLis = $collapsible.children('li');
+            var isActive = $collapsibleLi[0].classList.contains('active');
+            var index = $collapsibleLis.index($collapsibleLi);
+
+            if (isActive) {
+              this.close(index);
+            } else {
+              this.open(index);
+            }
+          }
+        }
+      }
+
+      /**
+       * Handle Collapsible Keydown
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleCollapsibleKeydown",
+      value: function _handleCollapsibleKeydown(e) {
+        if (e.keyCode === 13) {
+          this._handleCollapsibleClickBound(e);
+        }
+      }
+
+      /**
+       * Animate in collapsible slide
+       * @param {Number} index - 0th index of slide
+       */
+
+    }, {
+      key: "_animateIn",
+      value: function _animateIn(index) {
+        var _this6 = this;
+
+        var $collapsibleLi = this.$el.children('li').eq(index);
+        if ($collapsibleLi.length) {
+          var $body = $collapsibleLi.children('.collapsible-body');
+
+          anim.remove($body[0]);
+          $body.css({
+            display: 'block',
+            overflow: 'hidden',
+            height: 0,
+            paddingTop: '',
+            paddingBottom: ''
+          });
+
+          var pTop = $body.css('padding-top');
+          var pBottom = $body.css('padding-bottom');
+          var finalHeight = $body[0].scrollHeight;
+          $body.css({
+            paddingTop: 0,
+            paddingBottom: 0
+          });
+
+          anim({
+            targets: $body[0],
+            height: finalHeight,
+            paddingTop: pTop,
+            paddingBottom: pBottom,
+            duration: this.options.inDuration,
+            easing: 'easeInOutCubic',
+            complete: function (anim) {
+              $body.css({
+                overflow: '',
+                paddingTop: '',
+                paddingBottom: '',
+                height: ''
+              });
+
+              // onOpenEnd callback
+              if (typeof _this6.options.onOpenEnd === 'function') {
+                _this6.options.onOpenEnd.call(_this6, $collapsibleLi[0]);
+              }
+            }
+          });
+        }
+      }
+
+      /**
+       * Animate out collapsible slide
+       * @param {Number} index - 0th index of slide to open
+       */
+
+    }, {
+      key: "_animateOut",
+      value: function _animateOut(index) {
+        var _this7 = this;
+
+        var $collapsibleLi = this.$el.children('li').eq(index);
+        if ($collapsibleLi.length) {
+          var $body = $collapsibleLi.children('.collapsible-body');
+          anim.remove($body[0]);
+          $body.css('overflow', 'hidden');
+          anim({
+            targets: $body[0],
+            height: 0,
+            paddingTop: 0,
+            paddingBottom: 0,
+            duration: this.options.outDuration,
+            easing: 'easeInOutCubic',
+            complete: function () {
+              $body.css({
+                height: '',
+                overflow: '',
+                padding: '',
+                display: ''
+              });
+
+              // onCloseEnd callback
+              if (typeof _this7.options.onCloseEnd === 'function') {
+                _this7.options.onCloseEnd.call(_this7, $collapsibleLi[0]);
+              }
+            }
+          });
+        }
+      }
+
+      /**
+       * Open Collapsible
+       * @param {Number} index - 0th index of slide
+       */
+
+    }, {
+      key: "open",
+      value: function open(index) {
+        var _this8 = this;
+
+        var $collapsibleLi = this.$el.children('li').eq(index);
+        if ($collapsibleLi.length && !$collapsibleLi[0].classList.contains('active')) {
+          // onOpenStart callback
+          if (typeof this.options.onOpenStart === 'function') {
+            this.options.onOpenStart.call(this, $collapsibleLi[0]);
+          }
+
+          // Handle accordion behavior
+          if (this.options.accordion) {
+            var $collapsibleLis = this.$el.children('li');
+            var $activeLis = this.$el.children('li.active');
+            $activeLis.each(function (el) {
+              var index = $collapsibleLis.index($(el));
+              _this8.close(index);
+            });
+          }
+
+          // Animate in
+          $collapsibleLi[0].classList.add('active');
+          this._animateIn(index);
+        }
+      }
+
+      /**
+       * Close Collapsible
+       * @param {Number} index - 0th index of slide
+       */
+
+    }, {
+      key: "close",
+      value: function close(index) {
+        var $collapsibleLi = this.$el.children('li').eq(index);
+        if ($collapsibleLi.length && $collapsibleLi[0].classList.contains('active')) {
+          // onCloseStart callback
+          if (typeof this.options.onCloseStart === 'function') {
+            this.options.onCloseStart.call(this, $collapsibleLi[0]);
+          }
+
+          // Animate out
+          $collapsibleLi[0].classList.remove('active');
+          this._animateOut(index);
+        }
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(Collapsible.__proto__ || Object.getPrototypeOf(Collapsible), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Collapsible;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Collapsible;
+  }(Component);
+
+  M.Collapsible = Collapsible;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(Collapsible, 'collapsible', 'M_Collapsible');
+  }
+})(cash, M.anime);
+;(function ($, anim) {
+  'use strict';
+
+  var _defaults = {
+    alignment: 'left',
+    autoFocus: true,
+    constrainWidth: true,
+    container: null,
+    coverTrigger: true,
+    closeOnClick: true,
+    hover: false,
+    inDuration: 150,
+    outDuration: 250,
+    onOpenStart: null,
+    onOpenEnd: null,
+    onCloseStart: null,
+    onCloseEnd: null,
+    onItemClick: null
+  };
+
+  /**
+   * @class
+   */
+
+  var Dropdown = function (_Component2) {
+    _inherits(Dropdown, _Component2);
+
+    function Dropdown(el, options) {
+      _classCallCheck(this, Dropdown);
+
+      var _this9 = _possibleConstructorReturn(this, (Dropdown.__proto__ || Object.getPrototypeOf(Dropdown)).call(this, Dropdown, el, options));
+
+      _this9.el.M_Dropdown = _this9;
+      Dropdown._dropdowns.push(_this9);
+
+      _this9.id = M.getIdFromTrigger(el);
+      _this9.dropdownEl = document.getElementById(_this9.id);
+      _this9.$dropdownEl = $(_this9.dropdownEl);
+
+      /**
+       * Options for the dropdown
+       * @member Dropdown#options
+       * @prop {String} [alignment='left'] - Edge which the dropdown is aligned to
+       * @prop {Boolean} [autoFocus=true] - Automatically focus dropdown el for keyboard
+       * @prop {Boolean} [constrainWidth=true] - Constrain width to width of the button
+       * @prop {Element} container - Container element to attach dropdown to (optional)
+       * @prop {Boolean} [coverTrigger=true] - Place dropdown over trigger
+       * @prop {Boolean} [closeOnClick=true] - Close on click of dropdown item
+       * @prop {Boolean} [hover=false] - Open dropdown on hover
+       * @prop {Number} [inDuration=150] - Duration of open animation in ms
+       * @prop {Number} [outDuration=250] - Duration of close animation in ms
+       * @prop {Function} onOpenStart - Function called when dropdown starts opening
+       * @prop {Function} onOpenEnd - Function called when dropdown finishes opening
+       * @prop {Function} onCloseStart - Function called when dropdown starts closing
+       * @prop {Function} onCloseEnd - Function called when dropdown finishes closing
+       */
+      _this9.options = $.extend({}, Dropdown.defaults, options);
+
+      /**
+       * Describes open/close state of dropdown
+       * @type {Boolean}
+       */
+      _this9.isOpen = false;
+
+      /**
+       * Describes if dropdown content is scrollable
+       * @type {Boolean}
+       */
+      _this9.isScrollable = false;
+
+      /**
+       * Describes if touch moving on dropdown content
+       * @type {Boolean}
+       */
+      _this9.isTouchMoving = false;
+
+      _this9.focusedIndex = -1;
+      _this9.filterQuery = [];
+
+      // Move dropdown-content after dropdown-trigger
+      if (!!_this9.options.container) {
+        $(_this9.options.container).append(_this9.dropdownEl);
+      } else {
+        _this9.$el.after(_this9.dropdownEl);
+      }
+
+      _this9._makeDropdownFocusable();
+      _this9._resetFilterQueryBound = _this9._resetFilterQuery.bind(_this9);
+      _this9._handleDocumentClickBound = _this9._handleDocumentClick.bind(_this9);
+      _this9._handleDocumentTouchmoveBound = _this9._handleDocumentTouchmove.bind(_this9);
+      _this9._handleDropdownClickBound = _this9._handleDropdownClick.bind(_this9);
+      _this9._handleDropdownKeydownBound = _this9._handleDropdownKeydown.bind(_this9);
+      _this9._handleTriggerKeydownBound = _this9._handleTriggerKeydown.bind(_this9);
+      _this9._setupEventHandlers();
+      return _this9;
+    }
+
+    _createClass(Dropdown, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        this._resetDropdownStyles();
+        this._removeEventHandlers();
+        Dropdown._dropdowns.splice(Dropdown._dropdowns.indexOf(this), 1);
+        this.el.M_Dropdown = undefined;
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        // Trigger keydown handler
+        this.el.addEventListener('keydown', this._handleTriggerKeydownBound);
+
+        // Item click handler
+        this.dropdownEl.addEventListener('click', this._handleDropdownClickBound);
+
+        // Hover event handlers
+        if (this.options.hover) {
+          this._handleMouseEnterBound = this._handleMouseEnter.bind(this);
+          this.el.addEventListener('mouseenter', this._handleMouseEnterBound);
+          this._handleMouseLeaveBound = this._handleMouseLeave.bind(this);
+          this.el.addEventListener('mouseleave', this._handleMouseLeaveBound);
+          this.dropdownEl.addEventListener('mouseleave', this._handleMouseLeaveBound);
+
+          // Click event handlers
+        } else {
+          this._handleClickBound = this._handleClick.bind(this);
+          this.el.addEventListener('click', this._handleClickBound);
+        }
+      }
+
+      /**
+       * Remove Event Handlers
+       */
+
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        this.el.removeEventListener('keydown', this._handleTriggerKeydownBound);
+        this.dropdownEl.removeEventListener('click', this._handleDropdownClickBound);
+
+        if (this.options.hover) {
+          this.el.removeEventListener('mouseenter', this._handleMouseEnterBound);
+          this.el.removeEventListener('mouseleave', this._handleMouseLeaveBound);
+          this.dropdownEl.removeEventListener('mouseleave', this._handleMouseLeaveBound);
+        } else {
+          this.el.removeEventListener('click', this._handleClickBound);
+        }
+      }
+    }, {
+      key: "_setupTemporaryEventHandlers",
+      value: function _setupTemporaryEventHandlers() {
+        // Use capture phase event handler to prevent click
+        document.body.addEventListener('click', this._handleDocumentClickBound, true);
+        document.body.addEventListener('touchend', this._handleDocumentClickBound);
+        document.body.addEventListener('touchmove', this._handleDocumentTouchmoveBound);
+        this.dropdownEl.addEventListener('keydown', this._handleDropdownKeydownBound);
+      }
+    }, {
+      key: "_removeTemporaryEventHandlers",
+      value: function _removeTemporaryEventHandlers() {
+        // Use capture phase event handler to prevent click
+        document.body.removeEventListener('click', this._handleDocumentClickBound, true);
+        document.body.removeEventListener('touchend', this._handleDocumentClickBound);
+        document.body.removeEventListener('touchmove', this._handleDocumentTouchmoveBound);
+        this.dropdownEl.removeEventListener('keydown', this._handleDropdownKeydownBound);
+      }
+    }, {
+      key: "_handleClick",
+      value: function _handleClick(e) {
+        e.preventDefault();
+        this.open();
+      }
+    }, {
+      key: "_handleMouseEnter",
+      value: function _handleMouseEnter() {
+        this.open();
+      }
+    }, {
+      key: "_handleMouseLeave",
+      value: function _handleMouseLeave(e) {
+        var toEl = e.toElement || e.relatedTarget;
+        var leaveToDropdownContent = !!$(toEl).closest('.dropdown-content').length;
+        var leaveToActiveDropdownTrigger = false;
+
+        var $closestTrigger = $(toEl).closest('.dropdown-trigger');
+        if ($closestTrigger.length && !!$closestTrigger[0].M_Dropdown && $closestTrigger[0].M_Dropdown.isOpen) {
+          leaveToActiveDropdownTrigger = true;
+        }
+
+        // Close hover dropdown if mouse did not leave to either active dropdown-trigger or dropdown-content
+        if (!leaveToActiveDropdownTrigger && !leaveToDropdownContent) {
+          this.close();
+        }
+      }
+    }, {
+      key: "_handleDocumentClick",
+      value: function _handleDocumentClick(e) {
+        var _this10 = this;
+
+        var $target = $(e.target);
+        if (this.options.closeOnClick && $target.closest('.dropdown-content').length && !this.isTouchMoving) {
+          // isTouchMoving to check if scrolling on mobile.
+          setTimeout(function () {
+            _this10.close();
+          }, 0);
+        } else if ($target.closest('.dropdown-trigger').length || !$target.closest('.dropdown-content').length) {
+          setTimeout(function () {
+            _this10.close();
+          }, 0);
+        }
+        this.isTouchMoving = false;
+      }
+    }, {
+      key: "_handleTriggerKeydown",
+      value: function _handleTriggerKeydown(e) {
+        // ARROW DOWN OR ENTER WHEN SELECT IS CLOSED - open Dropdown
+        if ((e.which === M.keys.ARROW_DOWN || e.which === M.keys.ENTER) && !this.isOpen) {
+          e.preventDefault();
+          this.open();
+        }
+      }
+
+      /**
+       * Handle Document Touchmove
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleDocumentTouchmove",
+      value: function _handleDocumentTouchmove(e) {
+        var $target = $(e.target);
+        if ($target.closest('.dropdown-content').length) {
+          this.isTouchMoving = true;
+        }
+      }
+
+      /**
+       * Handle Dropdown Click
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleDropdownClick",
+      value: function _handleDropdownClick(e) {
+        // onItemClick callback
+        if (typeof this.options.onItemClick === 'function') {
+          var itemEl = $(e.target).closest('li')[0];
+          this.options.onItemClick.call(this, itemEl);
+        }
+      }
+
+      /**
+       * Handle Dropdown Keydown
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleDropdownKeydown",
+      value: function _handleDropdownKeydown(e) {
+        if (e.which === M.keys.TAB) {
+          e.preventDefault();
+          this.close();
+
+          // Navigate down dropdown list
+        } else if ((e.which === M.keys.ARROW_DOWN || e.which === M.keys.ARROW_UP) && this.isOpen) {
+          e.preventDefault();
+          var direction = e.which === M.keys.ARROW_DOWN ? 1 : -1;
+          var newFocusedIndex = this.focusedIndex;
+          var foundNewIndex = false;
+          do {
+            newFocusedIndex = newFocusedIndex + direction;
+
+            if (!!this.dropdownEl.children[newFocusedIndex] && this.dropdownEl.children[newFocusedIndex].tabIndex !== -1) {
+              foundNewIndex = true;
+              break;
+            }
+          } while (newFocusedIndex < this.dropdownEl.children.length && newFocusedIndex >= 0);
+
+          if (foundNewIndex) {
+            this.focusedIndex = newFocusedIndex;
+            this._focusFocusedItem();
+          }
+
+          // ENTER selects choice on focused item
+        } else if (e.which === M.keys.ENTER && this.isOpen) {
+          // Search for <a> and <button>
+          var focusedElement = this.dropdownEl.children[this.focusedIndex];
+          var $activatableElement = $(focusedElement).find('a, button').first();
+
+          // Click a or button tag if exists, otherwise click li tag
+          if (!!$activatableElement.length) {
+            $activatableElement[0].click();
+          } else if (!!focusedElement) {
+            focusedElement.click();
+          }
+
+          // Close dropdown on ESC
+        } else if (e.which === M.keys.ESC && this.isOpen) {
+          e.preventDefault();
+          this.close();
+        }
+
+        // CASE WHEN USER TYPE LETTERS
+        var letter = String.fromCharCode(e.which).toLowerCase(),
+            nonLetters = [9, 13, 27, 38, 40];
+        if (letter && nonLetters.indexOf(e.which) === -1) {
+          this.filterQuery.push(letter);
+
+          var string = this.filterQuery.join(''),
+              newOptionEl = $(this.dropdownEl).find('li').filter(function (el) {
+            return $(el).text().toLowerCase().indexOf(string) === 0;
+          })[0];
+
+          if (newOptionEl) {
+            this.focusedIndex = $(newOptionEl).index();
+            this._focusFocusedItem();
+          }
+        }
+
+        this.filterTimeout = setTimeout(this._resetFilterQueryBound, 1000);
+      }
+
+      /**
+       * Setup dropdown
+       */
+
+    }, {
+      key: "_resetFilterQuery",
+      value: function _resetFilterQuery() {
+        this.filterQuery = [];
+      }
+    }, {
+      key: "_resetDropdownStyles",
+      value: function _resetDropdownStyles() {
+        this.$dropdownEl.css({
+          display: '',
+          width: '',
+          height: '',
+          left: '',
+          top: '',
+          'transform-origin': '',
+          transform: '',
+          opacity: ''
+        });
+      }
+    }, {
+      key: "_makeDropdownFocusable",
+      value: function _makeDropdownFocusable() {
+        // Needed for arrow key navigation
+        this.dropdownEl.tabIndex = 0;
+
+        // Only set tabindex if it hasn't been set by user
+        $(this.dropdownEl).children().each(function (el) {
+          if (!el.getAttribute('tabindex')) {
+            el.setAttribute('tabindex', 0);
+          }
+        });
+      }
+    }, {
+      key: "_focusFocusedItem",
+      value: function _focusFocusedItem() {
+        if (this.focusedIndex >= 0 && this.focusedIndex < this.dropdownEl.children.length && this.options.autoFocus) {
+          this.dropdownEl.children[this.focusedIndex].focus();
+        }
+      }
+    }, {
+      key: "_getDropdownPosition",
+      value: function _getDropdownPosition() {
+        var offsetParentBRect = this.el.offsetParent.getBoundingClientRect();
+        var triggerBRect = this.el.getBoundingClientRect();
+        var dropdownBRect = this.dropdownEl.getBoundingClientRect();
+
+        var idealHeight = dropdownBRect.height;
+        var idealWidth = dropdownBRect.width;
+        var idealXPos = triggerBRect.left - dropdownBRect.left;
+        var idealYPos = triggerBRect.top - dropdownBRect.top;
+
+        var dropdownBounds = {
+          left: idealXPos,
+          top: idealYPos,
+          height: idealHeight,
+          width: idealWidth
+        };
+
+        // Countainer here will be closest ancestor with overflow: hidden
+        var closestOverflowParent = !!this.dropdownEl.offsetParent ? this.dropdownEl.offsetParent : this.dropdownEl.parentNode;
+
+        var alignments = M.checkPossibleAlignments(this.el, closestOverflowParent, dropdownBounds, this.options.coverTrigger ? 0 : triggerBRect.height);
+
+        var verticalAlignment = 'top';
+        var horizontalAlignment = this.options.alignment;
+        idealYPos += this.options.coverTrigger ? 0 : triggerBRect.height;
+
+        // Reset isScrollable
+        this.isScrollable = false;
+
+        if (!alignments.top) {
+          if (alignments.bottom) {
+            verticalAlignment = 'bottom';
+          } else {
+            this.isScrollable = true;
+
+            // Determine which side has most space and cutoff at correct height
+            if (alignments.spaceOnTop > alignments.spaceOnBottom) {
+              verticalAlignment = 'bottom';
+              idealHeight += alignments.spaceOnTop;
+              idealYPos -= alignments.spaceOnTop;
+            } else {
+              idealHeight += alignments.spaceOnBottom;
+            }
+          }
+        }
+
+        // If preferred horizontal alignment is possible
+        if (!alignments[horizontalAlignment]) {
+          var oppositeAlignment = horizontalAlignment === 'left' ? 'right' : 'left';
+          if (alignments[oppositeAlignment]) {
+            horizontalAlignment = oppositeAlignment;
+          } else {
+            // Determine which side has most space and cutoff at correct height
+            if (alignments.spaceOnLeft > alignments.spaceOnRight) {
+              horizontalAlignment = 'right';
+              idealWidth += alignments.spaceOnLeft;
+              idealXPos -= alignments.spaceOnLeft;
+            } else {
+              horizontalAlignment = 'left';
+              idealWidth += alignments.spaceOnRight;
+            }
+          }
+        }
+
+        if (verticalAlignment === 'bottom') {
+          idealYPos = idealYPos - dropdownBRect.height + (this.options.coverTrigger ? triggerBRect.height : 0);
+        }
+        if (horizontalAlignment === 'right') {
+          idealXPos = idealXPos - dropdownBRect.width + triggerBRect.width;
+        }
+        return {
+          x: idealXPos,
+          y: idealYPos,
+          verticalAlignment: verticalAlignment,
+          horizontalAlignment: horizontalAlignment,
+          height: idealHeight,
+          width: idealWidth
+        };
+      }
+
+      /**
+       * Animate in dropdown
+       */
+
+    }, {
+      key: "_animateIn",
+      value: function _animateIn() {
+        var _this11 = this;
+
+        anim.remove(this.dropdownEl);
+        anim({
+          targets: this.dropdownEl,
+          opacity: {
+            value: [0, 1],
+            easing: 'easeOutQuad'
+          },
+          scaleX: [0.3, 1],
+          scaleY: [0.3, 1],
+          duration: this.options.inDuration,
+          easing: 'easeOutQuint',
+          complete: function (anim) {
+            if (_this11.options.autoFocus) {
+              _this11.dropdownEl.focus();
+            }
+
+            // onOpenEnd callback
+            if (typeof _this11.options.onOpenEnd === 'function') {
+              _this11.options.onOpenEnd.call(_this11, _this11.el);
+            }
+          }
+        });
+      }
+
+      /**
+       * Animate out dropdown
+       */
+
+    }, {
+      key: "_animateOut",
+      value: function _animateOut() {
+        var _this12 = this;
+
+        anim.remove(this.dropdownEl);
+        anim({
+          targets: this.dropdownEl,
+          opacity: {
+            value: 0,
+            easing: 'easeOutQuint'
+          },
+          scaleX: 0.3,
+          scaleY: 0.3,
+          duration: this.options.outDuration,
+          easing: 'easeOutQuint',
+          complete: function (anim) {
+            _this12._resetDropdownStyles();
+
+            // onCloseEnd callback
+            if (typeof _this12.options.onCloseEnd === 'function') {
+              _this12.options.onCloseEnd.call(_this12, _this12.el);
+            }
+          }
+        });
+      }
+
+      /**
+       * Place dropdown
+       */
+
+    }, {
+      key: "_placeDropdown",
+      value: function _placeDropdown() {
+        // Set width before calculating positionInfo
+        var idealWidth = this.options.constrainWidth ? this.el.getBoundingClientRect().width : this.dropdownEl.getBoundingClientRect().width;
+        this.dropdownEl.style.width = idealWidth + 'px';
+
+        var positionInfo = this._getDropdownPosition();
+        this.dropdownEl.style.left = positionInfo.x + 'px';
+        this.dropdownEl.style.top = positionInfo.y + 'px';
+        this.dropdownEl.style.height = positionInfo.height + 'px';
+        this.dropdownEl.style.width = positionInfo.width + 'px';
+        this.dropdownEl.style.transformOrigin = (positionInfo.horizontalAlignment === 'left' ? '0' : '100%') + " " + (positionInfo.verticalAlignment === 'top' ? '0' : '100%');
+      }
+
+      /**
+       * Open Dropdown
+       */
+
+    }, {
+      key: "open",
+      value: function open() {
+        if (this.isOpen) {
+          return;
+        }
+        this.isOpen = true;
+
+        // onOpenStart callback
+        if (typeof this.options.onOpenStart === 'function') {
+          this.options.onOpenStart.call(this, this.el);
+        }
+
+        // Reset styles
+        this._resetDropdownStyles();
+        this.dropdownEl.style.display = 'block';
+
+        this._placeDropdown();
+        this._animateIn();
+        this._setupTemporaryEventHandlers();
+      }
+
+      /**
+       * Close Dropdown
+       */
+
+    }, {
+      key: "close",
+      value: function close() {
+        if (!this.isOpen) {
+          return;
+        }
+        this.isOpen = false;
+        this.focusedIndex = -1;
+
+        // onCloseStart callback
+        if (typeof this.options.onCloseStart === 'function') {
+          this.options.onCloseStart.call(this, this.el);
+        }
+
+        this._animateOut();
+        this._removeTemporaryEventHandlers();
+
+        if (this.options.autoFocus) {
+          this.el.focus();
+        }
+      }
+
+      /**
+       * Recalculate dimensions
+       */
+
+    }, {
+      key: "recalculateDimensions",
+      value: function recalculateDimensions() {
+        if (this.isOpen) {
+          this.$dropdownEl.css({
+            width: '',
+            height: '',
+            left: '',
+            top: '',
+            'transform-origin': ''
+          });
+          this._placeDropdown();
+        }
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(Dropdown.__proto__ || Object.getPrototypeOf(Dropdown), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Dropdown;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Dropdown;
+  }(Component);
+
+  /**
+   * @static
+   * @memberof Dropdown
+   */
+
+
+  Dropdown._dropdowns = [];
+
+  M.Dropdown = Dropdown;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(Dropdown, 'dropdown', 'M_Dropdown');
+  }
+})(cash, M.anime);
+;(function ($, anim) {
+  'use strict';
+
+  var _defaults = {
+    opacity: 0.5,
+    inDuration: 250,
+    outDuration: 250,
+    onOpenStart: null,
+    onOpenEnd: null,
+    onCloseStart: null,
+    onCloseEnd: null,
+    preventScrolling: true,
+    dismissible: true,
+    startingTop: '4%',
+    endingTop: '10%'
+  };
+
+  /**
+   * @class
+   *
+   */
+
+  var Modal = function (_Component3) {
+    _inherits(Modal, _Component3);
+
+    /**
+     * Construct Modal instance and set up overlay
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function Modal(el, options) {
+      _classCallCheck(this, Modal);
+
+      var _this13 = _possibleConstructorReturn(this, (Modal.__proto__ || Object.getPrototypeOf(Modal)).call(this, Modal, el, options));
+
+      _this13.el.M_Modal = _this13;
+
+      /**
+       * Options for the modal
+       * @member Modal#options
+       * @prop {Number} [opacity=0.5] - Opacity of the modal overlay
+       * @prop {Number} [inDuration=250] - Length in ms of enter transition
+       * @prop {Number} [outDuration=250] - Length in ms of exit transition
+       * @prop {Function} onOpenStart - Callback function called before modal is opened
+       * @prop {Function} onOpenEnd - Callback function called after modal is opened
+       * @prop {Function} onCloseStart - Callback function called before modal is closed
+       * @prop {Function} onCloseEnd - Callback function called after modal is closed
+       * @prop {Boolean} [dismissible=true] - Allow modal to be dismissed by keyboard or overlay click
+       * @prop {String} [startingTop='4%'] - startingTop
+       * @prop {String} [endingTop='10%'] - endingTop
+       */
+      _this13.options = $.extend({}, Modal.defaults, options);
+
+      /**
+       * Describes open/close state of modal
+       * @type {Boolean}
+       */
+      _this13.isOpen = false;
+
+      _this13.id = _this13.$el.attr('id');
+      _this13._openingTrigger = undefined;
+      _this13.$overlay = $('<div class="modal-overlay"></div>');
+      _this13.el.tabIndex = 0;
+      _this13._nthModalOpened = 0;
+
+      Modal._count++;
+      _this13._setupEventHandlers();
+      return _this13;
+    }
+
+    _createClass(Modal, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        Modal._count--;
+        this._removeEventHandlers();
+        this.el.removeAttribute('style');
+        this.$overlay.remove();
+        this.el.M_Modal = undefined;
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        this._handleOverlayClickBound = this._handleOverlayClick.bind(this);
+        this._handleModalCloseClickBound = this._handleModalCloseClick.bind(this);
+
+        if (Modal._count === 1) {
+          document.body.addEventListener('click', this._handleTriggerClick);
+        }
+        this.$overlay[0].addEventListener('click', this._handleOverlayClickBound);
+        this.el.addEventListener('click', this._handleModalCloseClickBound);
+      }
+
+      /**
+       * Remove Event Handlers
+       */
+
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        if (Modal._count === 0) {
+          document.body.removeEventListener('click', this._handleTriggerClick);
+        }
+        this.$overlay[0].removeEventListener('click', this._handleOverlayClickBound);
+        this.el.removeEventListener('click', this._handleModalCloseClickBound);
+      }
+
+      /**
+       * Handle Trigger Click
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleTriggerClick",
+      value: function _handleTriggerClick(e) {
+        var $trigger = $(e.target).closest('.modal-trigger');
+        if ($trigger.length) {
+          var modalId = M.getIdFromTrigger($trigger[0]);
+          var modalInstance = document.getElementById(modalId).M_Modal;
+          if (modalInstance) {
+            modalInstance.open($trigger);
+          }
+          e.preventDefault();
+        }
+      }
+
+      /**
+       * Handle Overlay Click
+       */
+
+    }, {
+      key: "_handleOverlayClick",
+      value: function _handleOverlayClick() {
+        if (this.options.dismissible) {
+          this.close();
+        }
+      }
+
+      /**
+       * Handle Modal Close Click
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleModalCloseClick",
+      value: function _handleModalCloseClick(e) {
+        var $closeTrigger = $(e.target).closest('.modal-close');
+        if ($closeTrigger.length) {
+          this.close();
+        }
+      }
+
+      /**
+       * Handle Keydown
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleKeydown",
+      value: function _handleKeydown(e) {
+        // ESC key
+        if (e.keyCode === 27 && this.options.dismissible) {
+          this.close();
+        }
+      }
+
+      /**
+       * Handle Focus
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleFocus",
+      value: function _handleFocus(e) {
+        // Only trap focus if this modal is the last model opened (prevents loops in nested modals).
+        if (!this.el.contains(e.target) && this._nthModalOpened === Modal._modalsOpen) {
+          this.el.focus();
+        }
+      }
+
+      /**
+       * Animate in modal
+       */
+
+    }, {
+      key: "_animateIn",
+      value: function _animateIn() {
+        var _this14 = this;
+
+        // Set initial styles
+        $.extend(this.el.style, {
+          display: 'block',
+          opacity: 0
+        });
+        $.extend(this.$overlay[0].style, {
+          display: 'block',
+          opacity: 0
+        });
+
+        // Animate overlay
+        anim({
+          targets: this.$overlay[0],
+          opacity: this.options.opacity,
+          duration: this.options.inDuration,
+          easing: 'easeOutQuad'
+        });
+
+        // Define modal animation options
+        var enterAnimOptions = {
+          targets: this.el,
+          duration: this.options.inDuration,
+          easing: 'easeOutCubic',
+          // Handle modal onOpenEnd callback
+          complete: function () {
+            if (typeof _this14.options.onOpenEnd === 'function') {
+              _this14.options.onOpenEnd.call(_this14, _this14.el, _this14._openingTrigger);
+            }
+          }
+        };
+
+        // Bottom sheet animation
+        if (this.el.classList.contains('bottom-sheet')) {
+          $.extend(enterAnimOptions, {
+            bottom: 0,
+            opacity: 1
+          });
+          anim(enterAnimOptions);
+
+          // Normal modal animation
+        } else {
+          $.extend(enterAnimOptions, {
+            top: [this.options.startingTop, this.options.endingTop],
+            opacity: 1,
+            scaleX: [0.8, 1],
+            scaleY: [0.8, 1]
+          });
+          anim(enterAnimOptions);
+        }
+      }
+
+      /**
+       * Animate out modal
+       */
+
+    }, {
+      key: "_animateOut",
+      value: function _animateOut() {
+        var _this15 = this;
+
+        // Animate overlay
+        anim({
+          targets: this.$overlay[0],
+          opacity: 0,
+          duration: this.options.outDuration,
+          easing: 'easeOutQuart'
+        });
+
+        // Define modal animation options
+        var exitAnimOptions = {
+          targets: this.el,
+          duration: this.options.outDuration,
+          easing: 'easeOutCubic',
+          // Handle modal ready callback
+          complete: function () {
+            _this15.el.style.display = 'none';
+            _this15.$overlay.remove();
+
+            // Call onCloseEnd callback
+            if (typeof _this15.options.onCloseEnd === 'function') {
+              _this15.options.onCloseEnd.call(_this15, _this15.el);
+            }
+          }
+        };
+
+        // Bottom sheet animation
+        if (this.el.classList.contains('bottom-sheet')) {
+          $.extend(exitAnimOptions, {
+            bottom: '-100%',
+            opacity: 0
+          });
+          anim(exitAnimOptions);
+
+          // Normal modal animation
+        } else {
+          $.extend(exitAnimOptions, {
+            top: [this.options.endingTop, this.options.startingTop],
+            opacity: 0,
+            scaleX: 0.8,
+            scaleY: 0.8
+          });
+          anim(exitAnimOptions);
+        }
+      }
+
+      /**
+       * Open Modal
+       * @param {cash} [$trigger]
+       */
+
+    }, {
+      key: "open",
+      value: function open($trigger) {
+        if (this.isOpen) {
+          return;
+        }
+
+        this.isOpen = true;
+        Modal._modalsOpen++;
+        this._nthModalOpened = Modal._modalsOpen;
+
+        // Set Z-Index based on number of currently open modals
+        this.$overlay[0].style.zIndex = 1000 + Modal._modalsOpen * 2;
+        this.el.style.zIndex = 1000 + Modal._modalsOpen * 2 + 1;
+
+        // Set opening trigger, undefined indicates modal was opened by javascript
+        this._openingTrigger = !!$trigger ? $trigger[0] : undefined;
+
+        // onOpenStart callback
+        if (typeof this.options.onOpenStart === 'function') {
+          this.options.onOpenStart.call(this, this.el, this._openingTrigger);
+        }
+
+        if (this.options.preventScrolling) {
+          document.body.style.overflow = 'hidden';
+        }
+
+        this.el.classList.add('open');
+        this.el.insertAdjacentElement('afterend', this.$overlay[0]);
+
+        if (this.options.dismissible) {
+          this._handleKeydownBound = this._handleKeydown.bind(this);
+          this._handleFocusBound = this._handleFocus.bind(this);
+          document.addEventListener('keydown', this._handleKeydownBound);
+          document.addEventListener('focus', this._handleFocusBound, true);
+        }
+
+        anim.remove(this.el);
+        anim.remove(this.$overlay[0]);
+        this._animateIn();
+
+        // Focus modal
+        this.el.focus();
+
+        return this;
+      }
+
+      /**
+       * Close Modal
+       */
+
+    }, {
+      key: "close",
+      value: function close() {
+        if (!this.isOpen) {
+          return;
+        }
+
+        this.isOpen = false;
+        Modal._modalsOpen--;
+        this._nthModalOpened = 0;
+
+        // Call onCloseStart callback
+        if (typeof this.options.onCloseStart === 'function') {
+          this.options.onCloseStart.call(this, this.el);
+        }
+
+        this.el.classList.remove('open');
+
+        // Enable body scrolling only if there are no more modals open.
+        if (Modal._modalsOpen === 0) {
+          document.body.style.overflow = '';
+        }
+
+        if (this.options.dismissible) {
+          document.removeEventListener('keydown', this._handleKeydownBound);
+          document.removeEventListener('focus', this._handleFocusBound, true);
+        }
+
+        anim.remove(this.el);
+        anim.remove(this.$overlay[0]);
+        this._animateOut();
+        return this;
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(Modal.__proto__ || Object.getPrototypeOf(Modal), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Modal;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Modal;
+  }(Component);
+
+  /**
+   * @static
+   * @memberof Modal
+   */
+
+
+  Modal._modalsOpen = 0;
+
+  /**
+   * @static
+   * @memberof Modal
+   */
+  Modal._count = 0;
+
+  M.Modal = Modal;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(Modal, 'modal', 'M_Modal');
+  }
+})(cash, M.anime);
+;(function ($, anim) {
+  'use strict';
+
+  var _defaults = {
+    inDuration: 275,
+    outDuration: 200,
+    onOpenStart: null,
+    onOpenEnd: null,
+    onCloseStart: null,
+    onCloseEnd: null
+  };
+
+  /**
+   * @class
+   *
+   */
+
+  var Materialbox = function (_Component4) {
+    _inherits(Materialbox, _Component4);
+
+    /**
+     * Construct Materialbox instance
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function Materialbox(el, options) {
+      _classCallCheck(this, Materialbox);
+
+      var _this16 = _possibleConstructorReturn(this, (Materialbox.__proto__ || Object.getPrototypeOf(Materialbox)).call(this, Materialbox, el, options));
+
+      _this16.el.M_Materialbox = _this16;
+
+      /**
+       * Options for the modal
+       * @member Materialbox#options
+       * @prop {Number} [inDuration=275] - Length in ms of enter transition
+       * @prop {Number} [outDuration=200] - Length in ms of exit transition
+       * @prop {Function} onOpenStart - Callback function called before materialbox is opened
+       * @prop {Function} onOpenEnd - Callback function called after materialbox is opened
+       * @prop {Function} onCloseStart - Callback function called before materialbox is closed
+       * @prop {Function} onCloseEnd - Callback function called after materialbox is closed
+       */
+      _this16.options = $.extend({}, Materialbox.defaults, options);
+
+      _this16.overlayActive = false;
+      _this16.doneAnimating = true;
+      _this16.placeholder = $('<div></div>').addClass('material-placeholder');
+      _this16.originalWidth = 0;
+      _this16.originalHeight = 0;
+      _this16.originInlineStyles = _this16.$el.attr('style');
+      _this16.caption = _this16.el.getAttribute('data-caption') || '';
+
+      // Wrap
+      _this16.$el.before(_this16.placeholder);
+      _this16.placeholder.append(_this16.$el);
+
+      _this16._setupEventHandlers();
+      return _this16;
+    }
+
+    _createClass(Materialbox, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        this._removeEventHandlers();
+        this.el.M_Materialbox = undefined;
+
+        // Unwrap image
+        $(this.placeholder).after(this.el).remove();
+
+        this.$el.removeAttr('style');
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        this._handleMaterialboxClickBound = this._handleMaterialboxClick.bind(this);
+        this.el.addEventListener('click', this._handleMaterialboxClickBound);
+      }
+
+      /**
+       * Remove Event Handlers
+       */
+
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        this.el.removeEventListener('click', this._handleMaterialboxClickBound);
+      }
+
+      /**
+       * Handle Materialbox Click
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleMaterialboxClick",
+      value: function _handleMaterialboxClick(e) {
+        // If already modal, return to original
+        if (this.doneAnimating === false || this.overlayActive && this.doneAnimating) {
+          this.close();
+        } else {
+          this.open();
+        }
+      }
+
+      /**
+       * Handle Window Scroll
+       */
+
+    }, {
+      key: "_handleWindowScroll",
+      value: function _handleWindowScroll() {
+        if (this.overlayActive) {
+          this.close();
+        }
+      }
+
+      /**
+       * Handle Window Resize
+       */
+
+    }, {
+      key: "_handleWindowResize",
+      value: function _handleWindowResize() {
+        if (this.overlayActive) {
+          this.close();
+        }
+      }
+
+      /**
+       * Handle Window Resize
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleWindowEscape",
+      value: function _handleWindowEscape(e) {
+        // ESC key
+        if (e.keyCode === 27 && this.doneAnimating && this.overlayActive) {
+          this.close();
+        }
+      }
+
+      /**
+       * Find ancestors with overflow: hidden; and make visible
+       */
+
+    }, {
+      key: "_makeAncestorsOverflowVisible",
+      value: function _makeAncestorsOverflowVisible() {
+        this.ancestorsChanged = $();
+        var ancestor = this.placeholder[0].parentNode;
+        while (ancestor !== null && !$(ancestor).is(document)) {
+          var curr = $(ancestor);
+          if (curr.css('overflow') !== 'visible') {
+            curr.css('overflow', 'visible');
+            if (this.ancestorsChanged === undefined) {
+              this.ancestorsChanged = curr;
+            } else {
+              this.ancestorsChanged = this.ancestorsChanged.add(curr);
+            }
+          }
+          ancestor = ancestor.parentNode;
+        }
+      }
+
+      /**
+       * Animate image in
+       */
+
+    }, {
+      key: "_animateImageIn",
+      value: function _animateImageIn() {
+        var _this17 = this;
+
+        var animOptions = {
+          targets: this.el,
+          height: [this.originalHeight, this.newHeight],
+          width: [this.originalWidth, this.newWidth],
+          left: M.getDocumentScrollLeft() + this.windowWidth / 2 - this.placeholder.offset().left - this.newWidth / 2,
+          top: M.getDocumentScrollTop() + this.windowHeight / 2 - this.placeholder.offset().top - this.newHeight / 2,
+          duration: this.options.inDuration,
+          easing: 'easeOutQuad',
+          complete: function () {
+            _this17.doneAnimating = true;
+
+            // onOpenEnd callback
+            if (typeof _this17.options.onOpenEnd === 'function') {
+              _this17.options.onOpenEnd.call(_this17, _this17.el);
+            }
+          }
+        };
+
+        // Override max-width or max-height if needed
+        this.maxWidth = this.$el.css('max-width');
+        this.maxHeight = this.$el.css('max-height');
+        if (this.maxWidth !== 'none') {
+          animOptions.maxWidth = this.newWidth;
+        }
+        if (this.maxHeight !== 'none') {
+          animOptions.maxHeight = this.newHeight;
+        }
+
+        anim(animOptions);
+      }
+
+      /**
+       * Animate image out
+       */
+
+    }, {
+      key: "_animateImageOut",
+      value: function _animateImageOut() {
+        var _this18 = this;
+
+        var animOptions = {
+          targets: this.el,
+          width: this.originalWidth,
+          height: this.originalHeight,
+          left: 0,
+          top: 0,
+          duration: this.options.outDuration,
+          easing: 'easeOutQuad',
+          complete: function () {
+            _this18.placeholder.css({
+              height: '',
+              width: '',
+              position: '',
+              top: '',
+              left: ''
+            });
+
+            // Revert to width or height attribute
+            if (_this18.attrWidth) {
+              _this18.$el.attr('width', _this18.attrWidth);
+            }
+            if (_this18.attrHeight) {
+              _this18.$el.attr('height', _this18.attrHeight);
+            }
+
+            _this18.$el.removeAttr('style');
+            _this18.originInlineStyles && _this18.$el.attr('style', _this18.originInlineStyles);
+
+            // Remove class
+            _this18.$el.removeClass('active');
+            _this18.doneAnimating = true;
+
+            // Remove overflow overrides on ancestors
+            if (_this18.ancestorsChanged.length) {
+              _this18.ancestorsChanged.css('overflow', '');
+            }
+
+            // onCloseEnd callback
+            if (typeof _this18.options.onCloseEnd === 'function') {
+              _this18.options.onCloseEnd.call(_this18, _this18.el);
+            }
+          }
+        };
+
+        anim(animOptions);
+      }
+
+      /**
+       * Update open and close vars
+       */
+
+    }, {
+      key: "_updateVars",
+      value: function _updateVars() {
+        this.windowWidth = window.innerWidth;
+        this.windowHeight = window.innerHeight;
+        this.caption = this.el.getAttribute('data-caption') || '';
+      }
+
+      /**
+       * Open Materialbox
+       */
+
+    }, {
+      key: "open",
+      value: function open() {
+        var _this19 = this;
+
+        this._updateVars();
+        this.originalWidth = this.el.getBoundingClientRect().width;
+        this.originalHeight = this.el.getBoundingClientRect().height;
+
+        // Set states
+        this.doneAnimating = false;
+        this.$el.addClass('active');
+        this.overlayActive = true;
+
+        // onOpenStart callback
+        if (typeof this.options.onOpenStart === 'function') {
+          this.options.onOpenStart.call(this, this.el);
+        }
+
+        // Set positioning for placeholder
+        this.placeholder.css({
+          width: this.placeholder[0].getBoundingClientRect().width + 'px',
+          height: this.placeholder[0].getBoundingClientRect().height + 'px',
+          position: 'relative',
+          top: 0,
+          left: 0
+        });
+
+        this._makeAncestorsOverflowVisible();
+
+        // Set css on origin
+        this.$el.css({
+          position: 'absolute',
+          'z-index': 1000,
+          'will-change': 'left, top, width, height'
+        });
+
+        // Change from width or height attribute to css
+        this.attrWidth = this.$el.attr('width');
+        this.attrHeight = this.$el.attr('height');
+        if (this.attrWidth) {
+          this.$el.css('width', this.attrWidth + 'px');
+          this.$el.removeAttr('width');
+        }
+        if (this.attrHeight) {
+          this.$el.css('width', this.attrHeight + 'px');
+          this.$el.removeAttr('height');
+        }
+
+        // Add overlay
+        this.$overlay = $('<div id="materialbox-overlay"></div>').css({
+          opacity: 0
+        }).one('click', function () {
+          if (_this19.doneAnimating) {
+            _this19.close();
+          }
+        });
+
+        // Put before in origin image to preserve z-index layering.
+        this.$el.before(this.$overlay);
+
+        // Set dimensions if needed
+        var overlayOffset = this.$overlay[0].getBoundingClientRect();
+        this.$overlay.css({
+          width: this.windowWidth + 'px',
+          height: this.windowHeight + 'px',
+          left: -1 * overlayOffset.left + 'px',
+          top: -1 * overlayOffset.top + 'px'
+        });
+
+        anim.remove(this.el);
+        anim.remove(this.$overlay[0]);
+
+        // Animate Overlay
+        anim({
+          targets: this.$overlay[0],
+          opacity: 1,
+          duration: this.options.inDuration,
+          easing: 'easeOutQuad'
+        });
+
+        // Add and animate caption if it exists
+        if (this.caption !== '') {
+          if (this.$photocaption) {
+            anim.remove(this.$photoCaption[0]);
+          }
+          this.$photoCaption = $('<div class="materialbox-caption"></div>');
+          this.$photoCaption.text(this.caption);
+          $('body').append(this.$photoCaption);
+          this.$photoCaption.css({ display: 'inline' });
+
+          anim({
+            targets: this.$photoCaption[0],
+            opacity: 1,
+            duration: this.options.inDuration,
+            easing: 'easeOutQuad'
+          });
+        }
+
+        // Resize Image
+        var ratio = 0;
+        var widthPercent = this.originalWidth / this.windowWidth;
+        var heightPercent = this.originalHeight / this.windowHeight;
+        this.newWidth = 0;
+        this.newHeight = 0;
+
+        if (widthPercent > heightPercent) {
+          ratio = this.originalHeight / this.originalWidth;
+          this.newWidth = this.windowWidth * 0.9;
+          this.newHeight = this.windowWidth * 0.9 * ratio;
+        } else {
+          ratio = this.originalWidth / this.originalHeight;
+          this.newWidth = this.windowHeight * 0.9 * ratio;
+          this.newHeight = this.windowHeight * 0.9;
+        }
+
+        this._animateImageIn();
+
+        // Handle Exit triggers
+        this._handleWindowScrollBound = this._handleWindowScroll.bind(this);
+        this._handleWindowResizeBound = this._handleWindowResize.bind(this);
+        this._handleWindowEscapeBound = this._handleWindowEscape.bind(this);
+
+        window.addEventListener('scroll', this._handleWindowScrollBound);
+        window.addEventListener('resize', this._handleWindowResizeBound);
+        window.addEventListener('keyup', this._handleWindowEscapeBound);
+      }
+
+      /**
+       * Close Materialbox
+       */
+
+    }, {
+      key: "close",
+      value: function close() {
+        var _this20 = this;
+
+        this._updateVars();
+        this.doneAnimating = false;
+
+        // onCloseStart callback
+        if (typeof this.options.onCloseStart === 'function') {
+          this.options.onCloseStart.call(this, this.el);
+        }
+
+        anim.remove(this.el);
+        anim.remove(this.$overlay[0]);
+
+        if (this.caption !== '') {
+          anim.remove(this.$photoCaption[0]);
+        }
+
+        // disable exit handlers
+        window.removeEventListener('scroll', this._handleWindowScrollBound);
+        window.removeEventListener('resize', this._handleWindowResizeBound);
+        window.removeEventListener('keyup', this._handleWindowEscapeBound);
+
+        anim({
+          targets: this.$overlay[0],
+          opacity: 0,
+          duration: this.options.outDuration,
+          easing: 'easeOutQuad',
+          complete: function () {
+            _this20.overlayActive = false;
+            _this20.$overlay.remove();
+          }
+        });
+
+        this._animateImageOut();
+
+        // Remove Caption + reset css settings on image
+        if (this.caption !== '') {
+          anim({
+            targets: this.$photoCaption[0],
+            opacity: 0,
+            duration: this.options.outDuration,
+            easing: 'easeOutQuad',
+            complete: function () {
+              _this20.$photoCaption.remove();
+            }
+          });
+        }
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(Materialbox.__proto__ || Object.getPrototypeOf(Materialbox), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Materialbox;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Materialbox;
+  }(Component);
+
+  M.Materialbox = Materialbox;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(Materialbox, 'materialbox', 'M_Materialbox');
+  }
+})(cash, M.anime);
+;(function ($) {
+  'use strict';
+
+  var _defaults = {
+    responsiveThreshold: 0 // breakpoint for swipeable
+  };
+
+  var Parallax = function (_Component5) {
+    _inherits(Parallax, _Component5);
+
+    function Parallax(el, options) {
+      _classCallCheck(this, Parallax);
+
+      var _this21 = _possibleConstructorReturn(this, (Parallax.__proto__ || Object.getPrototypeOf(Parallax)).call(this, Parallax, el, options));
+
+      _this21.el.M_Parallax = _this21;
+
+      /**
+       * Options for the Parallax
+       * @member Parallax#options
+       * @prop {Number} responsiveThreshold
+       */
+      _this21.options = $.extend({}, Parallax.defaults, options);
+      _this21._enabled = window.innerWidth > _this21.options.responsiveThreshold;
+
+      _this21.$img = _this21.$el.find('img').first();
+      _this21.$img.each(function () {
+        var el = this;
+        if (el.complete) $(el).trigger('load');
+      });
+
+      _this21._updateParallax();
+      _this21._setupEventHandlers();
+      _this21._setupStyles();
+
+      Parallax._parallaxes.push(_this21);
+      return _this21;
+    }
+
+    _createClass(Parallax, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        Parallax._parallaxes.splice(Parallax._parallaxes.indexOf(this), 1);
+        this.$img[0].style.transform = '';
+        this._removeEventHandlers();
+
+        this.$el[0].M_Parallax = undefined;
+      }
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        this._handleImageLoadBound = this._handleImageLoad.bind(this);
+        this.$img[0].addEventListener('load', this._handleImageLoadBound);
+
+        if (Parallax._parallaxes.length === 0) {
+          Parallax._handleScrollThrottled = M.throttle(Parallax._handleScroll, 5);
+          window.addEventListener('scroll', Parallax._handleScrollThrottled);
+
+          Parallax._handleWindowResizeThrottled = M.throttle(Parallax._handleWindowResize, 5);
+          window.addEventListener('resize', Parallax._handleWindowResizeThrottled);
+        }
+      }
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        this.$img[0].removeEventListener('load', this._handleImageLoadBound);
+
+        if (Parallax._parallaxes.length === 0) {
+          window.removeEventListener('scroll', Parallax._handleScrollThrottled);
+          window.removeEventListener('resize', Parallax._handleWindowResizeThrottled);
+        }
+      }
+    }, {
+      key: "_setupStyles",
+      value: function _setupStyles() {
+        this.$img[0].style.opacity = 1;
+      }
+    }, {
+      key: "_handleImageLoad",
+      value: function _handleImageLoad() {
+        this._updateParallax();
+      }
+    }, {
+      key: "_updateParallax",
+      value: function _updateParallax() {
+        var containerHeight = this.$el.height() > 0 ? this.el.parentNode.offsetHeight : 500;
+        var imgHeight = this.$img[0].offsetHeight;
+        var parallaxDist = imgHeight - containerHeight;
+        var bottom = this.$el.offset().top + containerHeight;
+        var top = this.$el.offset().top;
+        var scrollTop = M.getDocumentScrollTop();
+        var windowHeight = window.innerHeight;
+        var windowBottom = scrollTop + windowHeight;
+        var percentScrolled = (windowBottom - top) / (containerHeight + windowHeight);
+        var parallax = parallaxDist * percentScrolled;
+
+        if (!this._enabled) {
+          this.$img[0].style.transform = '';
+        } else if (bottom > scrollTop && top < scrollTop + windowHeight) {
+          this.$img[0].style.transform = "translate3D(-50%, " + parallax + "px, 0)";
+        }
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(Parallax.__proto__ || Object.getPrototypeOf(Parallax), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Parallax;
+      }
+    }, {
+      key: "_handleScroll",
+      value: function _handleScroll() {
+        for (var i = 0; i < Parallax._parallaxes.length; i++) {
+          var parallaxInstance = Parallax._parallaxes[i];
+          parallaxInstance._updateParallax.call(parallaxInstance);
+        }
+      }
+    }, {
+      key: "_handleWindowResize",
+      value: function _handleWindowResize() {
+        for (var i = 0; i < Parallax._parallaxes.length; i++) {
+          var parallaxInstance = Parallax._parallaxes[i];
+          parallaxInstance._enabled = window.innerWidth > parallaxInstance.options.responsiveThreshold;
+        }
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Parallax;
+  }(Component);
+
+  /**
+   * @static
+   * @memberof Parallax
+   */
+
+
+  Parallax._parallaxes = [];
+
+  M.Parallax = Parallax;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(Parallax, 'parallax', 'M_Parallax');
+  }
+})(cash);
+;(function ($, anim) {
+  'use strict';
+
+  var _defaults = {
+    duration: 300,
+    onShow: null,
+    swipeable: false,
+    responsiveThreshold: Infinity // breakpoint for swipeable
+  };
+
+  /**
+   * @class
+   *
+   */
+
+  var Tabs = function (_Component6) {
+    _inherits(Tabs, _Component6);
+
+    /**
+     * Construct Tabs instance
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function Tabs(el, options) {
+      _classCallCheck(this, Tabs);
+
+      var _this22 = _possibleConstructorReturn(this, (Tabs.__proto__ || Object.getPrototypeOf(Tabs)).call(this, Tabs, el, options));
+
+      _this22.el.M_Tabs = _this22;
+
+      /**
+       * Options for the Tabs
+       * @member Tabs#options
+       * @prop {Number} duration
+       * @prop {Function} onShow
+       * @prop {Boolean} swipeable
+       * @prop {Number} responsiveThreshold
+       */
+      _this22.options = $.extend({}, Tabs.defaults, options);
+
+      // Setup
+      _this22.$tabLinks = _this22.$el.children('li.tab').children('a');
+      _this22.index = 0;
+      _this22._setupActiveTabLink();
+
+      // Setup tabs content
+      if (_this22.options.swipeable) {
+        _this22._setupSwipeableTabs();
+      } else {
+        _this22._setupNormalTabs();
+      }
+
+      // Setup tabs indicator after content to ensure accurate widths
+      _this22._setTabsAndTabWidth();
+      _this22._createIndicator();
+
+      _this22._setupEventHandlers();
+      return _this22;
+    }
+
+    _createClass(Tabs, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        this._removeEventHandlers();
+        this._indicator.parentNode.removeChild(this._indicator);
+
+        if (this.options.swipeable) {
+          this._teardownSwipeableTabs();
+        } else {
+          this._teardownNormalTabs();
+        }
+
+        this.$el[0].M_Tabs = undefined;
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        this._handleWindowResizeBound = this._handleWindowResize.bind(this);
+        window.addEventListener('resize', this._handleWindowResizeBound);
+
+        this._handleTabClickBound = this._handleTabClick.bind(this);
+        this.el.addEventListener('click', this._handleTabClickBound);
+      }
+
+      /**
+       * Remove Event Handlers
+       */
+
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        window.removeEventListener('resize', this._handleWindowResizeBound);
+        this.el.removeEventListener('click', this._handleTabClickBound);
+      }
+
+      /**
+       * Handle window Resize
+       */
+
+    }, {
+      key: "_handleWindowResize",
+      value: function _handleWindowResize() {
+        this._setTabsAndTabWidth();
+
+        if (this.tabWidth !== 0 && this.tabsWidth !== 0) {
+          this._indicator.style.left = this._calcLeftPos(this.$activeTabLink) + 'px';
+          this._indicator.style.right = this._calcRightPos(this.$activeTabLink) + 'px';
+        }
+      }
+
+      /**
+       * Handle tab click
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleTabClick",
+      value: function _handleTabClick(e) {
+        var _this23 = this;
+
+        var tab = $(e.target).closest('li.tab');
+        var tabLink = $(e.target).closest('a');
+
+        // Handle click on tab link only
+        if (!tabLink.length || !tabLink.parent().hasClass('tab')) {
+          return;
+        }
+
+        if (tab.hasClass('disabled')) {
+          e.preventDefault();
+          return;
+        }
+
+        // Act as regular link if target attribute is specified.
+        if (!!tabLink.attr('target')) {
+          return;
+        }
+
+        // Make the old tab inactive.
+        this.$activeTabLink.removeClass('active');
+        var $oldContent = this.$content;
+
+        // Update the variables with the new link and content
+        this.$activeTabLink = tabLink;
+        this.$content = $(M.escapeHash(tabLink[0].hash));
+        this.$tabLinks = this.$el.children('li.tab').children('a');
+
+        // Make the tab active.
+        this.$activeTabLink.addClass('active');
+        var prevIndex = this.index;
+        this.index = Math.max(this.$tabLinks.index(tabLink), 0);
+
+        // Swap content
+        if (this.options.swipeable) {
+          if (this._tabsCarousel) {
+            this._tabsCarousel.set(this.index, function () {
+              if (typeof _this23.options.onShow === 'function') {
+                _this23.options.onShow.call(_this23, _this23.$content[0]);
+              }
+            });
+          }
+        } else {
+          if (this.$content.length) {
+            this.$content[0].style.display = 'block';
+            this.$content.addClass('active');
+            if (typeof this.options.onShow === 'function') {
+              this.options.onShow.call(this, this.$content[0]);
+            }
+
+            if ($oldContent.length && !$oldContent.is(this.$content)) {
+              $oldContent[0].style.display = 'none';
+              $oldContent.removeClass('active');
+            }
+          }
+        }
+
+        // Update widths after content is swapped (scrollbar bugfix)
+        this._setTabsAndTabWidth();
+
+        // Update indicator
+        this._animateIndicator(prevIndex);
+
+        // Prevent the anchor's default click action
+        e.preventDefault();
+      }
+
+      /**
+       * Generate elements for tab indicator.
+       */
+
+    }, {
+      key: "_createIndicator",
+      value: function _createIndicator() {
+        var _this24 = this;
+
+        var indicator = document.createElement('li');
+        indicator.classList.add('indicator');
+
+        this.el.appendChild(indicator);
+        this._indicator = indicator;
+
+        setTimeout(function () {
+          _this24._indicator.style.left = _this24._calcLeftPos(_this24.$activeTabLink) + 'px';
+          _this24._indicator.style.right = _this24._calcRightPos(_this24.$activeTabLink) + 'px';
+        }, 0);
+      }
+
+      /**
+       * Setup first active tab link.
+       */
+
+    }, {
+      key: "_setupActiveTabLink",
+      value: function _setupActiveTabLink() {
+        // If the location.hash matches one of the links, use that as the active tab.
+        this.$activeTabLink = $(this.$tabLinks.filter('[href="' + location.hash + '"]'));
+
+        // If no match is found, use the first link or any with class 'active' as the initial active tab.
+        if (this.$activeTabLink.length === 0) {
+          this.$activeTabLink = this.$el.children('li.tab').children('a.active').first();
+        }
+        if (this.$activeTabLink.length === 0) {
+          this.$activeTabLink = this.$el.children('li.tab').children('a').first();
+        }
+
+        this.$tabLinks.removeClass('active');
+        this.$activeTabLink[0].classList.add('active');
+
+        this.index = Math.max(this.$tabLinks.index(this.$activeTabLink), 0);
+
+        if (this.$activeTabLink.length) {
+          this.$content = $(M.escapeHash(this.$activeTabLink[0].hash));
+          this.$content.addClass('active');
+        }
+      }
+
+      /**
+       * Setup swipeable tabs
+       */
+
+    }, {
+      key: "_setupSwipeableTabs",
+      value: function _setupSwipeableTabs() {
+        var _this25 = this;
+
+        // Change swipeable according to responsive threshold
+        if (window.innerWidth > this.options.responsiveThreshold) {
+          this.options.swipeable = false;
+        }
+
+        var $tabsContent = $();
+        this.$tabLinks.each(function (link) {
+          var $currContent = $(M.escapeHash(link.hash));
+          $currContent.addClass('carousel-item');
+          $tabsContent = $tabsContent.add($currContent);
+        });
+
+        var $tabsWrapper = $('<div class="tabs-content carousel carousel-slider"></div>');
+        $tabsContent.first().before($tabsWrapper);
+        $tabsWrapper.append($tabsContent);
+        $tabsContent[0].style.display = '';
+
+        // Keep active tab index to set initial carousel slide
+        var activeTabIndex = this.$activeTabLink.closest('.tab').index();
+
+        this._tabsCarousel = M.Carousel.init($tabsWrapper[0], {
+          fullWidth: true,
+          noWrap: true,
+          onCycleTo: function (item) {
+            var prevIndex = _this25.index;
+            _this25.index = $(item).index();
+            _this25.$activeTabLink.removeClass('active');
+            _this25.$activeTabLink = _this25.$tabLinks.eq(_this25.index);
+            _this25.$activeTabLink.addClass('active');
+            _this25._animateIndicator(prevIndex);
+            if (typeof _this25.options.onShow === 'function') {
+              _this25.options.onShow.call(_this25, _this25.$content[0]);
+            }
+          }
+        });
+
+        // Set initial carousel slide to active tab
+        this._tabsCarousel.set(activeTabIndex);
+      }
+
+      /**
+       * Teardown normal tabs.
+       */
+
+    }, {
+      key: "_teardownSwipeableTabs",
+      value: function _teardownSwipeableTabs() {
+        var $tabsWrapper = this._tabsCarousel.$el;
+        this._tabsCarousel.destroy();
+
+        // Unwrap
+        $tabsWrapper.after($tabsWrapper.children());
+        $tabsWrapper.remove();
+      }
+
+      /**
+       * Setup normal tabs.
+       */
+
+    }, {
+      key: "_setupNormalTabs",
+      value: function _setupNormalTabs() {
+        // Hide Tabs Content
+        this.$tabLinks.not(this.$activeTabLink).each(function (link) {
+          if (!!link.hash) {
+            var $currContent = $(M.escapeHash(link.hash));
+            if ($currContent.length) {
+              $currContent[0].style.display = 'none';
+            }
+          }
+        });
+      }
+
+      /**
+       * Teardown normal tabs.
+       */
+
+    }, {
+      key: "_teardownNormalTabs",
+      value: function _teardownNormalTabs() {
+        // show Tabs Content
+        this.$tabLinks.each(function (link) {
+          if (!!link.hash) {
+            var $currContent = $(M.escapeHash(link.hash));
+            if ($currContent.length) {
+              $currContent[0].style.display = '';
+            }
+          }
+        });
+      }
+
+      /**
+       * set tabs and tab width
+       */
+
+    }, {
+      key: "_setTabsAndTabWidth",
+      value: function _setTabsAndTabWidth() {
+        this.tabsWidth = this.$el.width();
+        this.tabWidth = Math.max(this.tabsWidth, this.el.scrollWidth) / this.$tabLinks.length;
+      }
+
+      /**
+       * Finds right attribute for indicator based on active tab.
+       * @param {cash} el
+       */
+
+    }, {
+      key: "_calcRightPos",
+      value: function _calcRightPos(el) {
+        return Math.ceil(this.tabsWidth - el.position().left - el[0].getBoundingClientRect().width);
+      }
+
+      /**
+       * Finds left attribute for indicator based on active tab.
+       * @param {cash} el
+       */
+
+    }, {
+      key: "_calcLeftPos",
+      value: function _calcLeftPos(el) {
+        return Math.floor(el.position().left);
+      }
+    }, {
+      key: "updateTabIndicator",
+      value: function updateTabIndicator() {
+        this._setTabsAndTabWidth();
+        this._animateIndicator(this.index);
+      }
+
+      /**
+       * Animates Indicator to active tab.
+       * @param {Number} prevIndex
+       */
+
+    }, {
+      key: "_animateIndicator",
+      value: function _animateIndicator(prevIndex) {
+        var leftDelay = 0,
+            rightDelay = 0;
+
+        if (this.index - prevIndex >= 0) {
+          leftDelay = 90;
+        } else {
+          rightDelay = 90;
+        }
+
+        // Animate
+        var animOptions = {
+          targets: this._indicator,
+          left: {
+            value: this._calcLeftPos(this.$activeTabLink),
+            delay: leftDelay
+          },
+          right: {
+            value: this._calcRightPos(this.$activeTabLink),
+            delay: rightDelay
+          },
+          duration: this.options.duration,
+          easing: 'easeOutQuad'
+        };
+        anim.remove(this._indicator);
+        anim(animOptions);
+      }
+
+      /**
+       * Select tab.
+       * @param {String} tabId
+       */
+
+    }, {
+      key: "select",
+      value: function select(tabId) {
+        var tab = this.$tabLinks.filter('[href="#' + tabId + '"]');
+        if (tab.length) {
+          tab.trigger('click');
+        }
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(Tabs.__proto__ || Object.getPrototypeOf(Tabs), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Tabs;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Tabs;
+  }(Component);
+
+  M.Tabs = Tabs;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(Tabs, 'tabs', 'M_Tabs');
+  }
+})(cash, M.anime);
+;(function ($, anim) {
+  'use strict';
+
+  var _defaults = {
+    exitDelay: 200,
+    enterDelay: 0,
+    html: null,
+    margin: 5,
+    inDuration: 250,
+    outDuration: 200,
+    position: 'bottom',
+    transitionMovement: 10
+  };
+
+  /**
+   * @class
+   *
+   */
+
+  var Tooltip = function (_Component7) {
+    _inherits(Tooltip, _Component7);
+
+    /**
+     * Construct Tooltip instance
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function Tooltip(el, options) {
+      _classCallCheck(this, Tooltip);
+
+      var _this26 = _possibleConstructorReturn(this, (Tooltip.__proto__ || Object.getPrototypeOf(Tooltip)).call(this, Tooltip, el, options));
+
+      _this26.el.M_Tooltip = _this26;
+      _this26.options = $.extend({}, Tooltip.defaults, options);
+
+      _this26.isOpen = false;
+      _this26.isHovered = false;
+      _this26.isFocused = false;
+      _this26._appendTooltipEl();
+      _this26._setupEventHandlers();
+      return _this26;
+    }
+
+    _createClass(Tooltip, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        $(this.tooltipEl).remove();
+        this._removeEventHandlers();
+        this.el.M_Tooltip = undefined;
+      }
+    }, {
+      key: "_appendTooltipEl",
+      value: function _appendTooltipEl() {
+        var tooltipEl = document.createElement('div');
+        tooltipEl.classList.add('material-tooltip');
+        this.tooltipEl = tooltipEl;
+
+        var tooltipContentEl = document.createElement('div');
+        tooltipContentEl.classList.add('tooltip-content');
+        tooltipContentEl.innerHTML = this.options.html;
+        tooltipEl.appendChild(tooltipContentEl);
+        document.body.appendChild(tooltipEl);
+      }
+    }, {
+      key: "_updateTooltipContent",
+      value: function _updateTooltipContent() {
+        this.tooltipEl.querySelector('.tooltip-content').innerHTML = this.options.html;
+      }
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        this._handleMouseEnterBound = this._handleMouseEnter.bind(this);
+        this._handleMouseLeaveBound = this._handleMouseLeave.bind(this);
+        this._handleFocusBound = this._handleFocus.bind(this);
+        this._handleBlurBound = this._handleBlur.bind(this);
+        this.el.addEventListener('mouseenter', this._handleMouseEnterBound);
+        this.el.addEventListener('mouseleave', this._handleMouseLeaveBound);
+        this.el.addEventListener('focus', this._handleFocusBound, true);
+        this.el.addEventListener('blur', this._handleBlurBound, true);
+      }
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        this.el.removeEventListener('mouseenter', this._handleMouseEnterBound);
+        this.el.removeEventListener('mouseleave', this._handleMouseLeaveBound);
+        this.el.removeEventListener('focus', this._handleFocusBound, true);
+        this.el.removeEventListener('blur', this._handleBlurBound, true);
+      }
+    }, {
+      key: "open",
+      value: function open(isManual) {
+        if (this.isOpen) {
+          return;
+        }
+        isManual = isManual === undefined ? true : undefined; // Default value true
+        this.isOpen = true;
+        // Update tooltip content with HTML attribute options
+        this.options = $.extend({}, this.options, this._getAttributeOptions());
+        this._updateTooltipContent();
+        this._setEnterDelayTimeout(isManual);
+      }
+    }, {
+      key: "close",
+      value: function close() {
+        if (!this.isOpen) {
+          return;
+        }
+
+        this.isHovered = false;
+        this.isFocused = false;
+        this.isOpen = false;
+        this._setExitDelayTimeout();
+      }
+
+      /**
+       * Create timeout which delays when the tooltip closes
+       */
+
+    }, {
+      key: "_setExitDelayTimeout",
+      value: function _setExitDelayTimeout() {
+        var _this27 = this;
+
+        clearTimeout(this._exitDelayTimeout);
+
+        this._exitDelayTimeout = setTimeout(function () {
+          if (_this27.isHovered || _this27.isFocused) {
+            return;
+          }
+
+          _this27._animateOut();
+        }, this.options.exitDelay);
+      }
+
+      /**
+       * Create timeout which delays when the toast closes
+       */
+
+    }, {
+      key: "_setEnterDelayTimeout",
+      value: function _setEnterDelayTimeout(isManual) {
+        var _this28 = this;
+
+        clearTimeout(this._enterDelayTimeout);
+
+        this._enterDelayTimeout = setTimeout(function () {
+          if (!_this28.isHovered && !_this28.isFocused && !isManual) {
+            return;
+          }
+
+          _this28._animateIn();
+        }, this.options.enterDelay);
+      }
+    }, {
+      key: "_positionTooltip",
+      value: function _positionTooltip() {
+        var origin = this.el,
+            tooltip = this.tooltipEl,
+            originHeight = origin.offsetHeight,
+            originWidth = origin.offsetWidth,
+            tooltipHeight = tooltip.offsetHeight,
+            tooltipWidth = tooltip.offsetWidth,
+            newCoordinates = void 0,
+            margin = this.options.margin,
+            targetTop = void 0,
+            targetLeft = void 0;
+
+        this.xMovement = 0, this.yMovement = 0;
+
+        targetTop = origin.getBoundingClientRect().top + M.getDocumentScrollTop();
+        targetLeft = origin.getBoundingClientRect().left + M.getDocumentScrollLeft();
+
+        if (this.options.position === 'top') {
+          targetTop += -tooltipHeight - margin;
+          targetLeft += originWidth / 2 - tooltipWidth / 2;
+          this.yMovement = -this.options.transitionMovement;
+        } else if (this.options.position === 'right') {
+          targetTop += originHeight / 2 - tooltipHeight / 2;
+          targetLeft += originWidth + margin;
+          this.xMovement = this.options.transitionMovement;
+        } else if (this.options.position === 'left') {
+          targetTop += originHeight / 2 - tooltipHeight / 2;
+          targetLeft += -tooltipWidth - margin;
+          this.xMovement = -this.options.transitionMovement;
+        } else {
+          targetTop += originHeight + margin;
+          targetLeft += originWidth / 2 - tooltipWidth / 2;
+          this.yMovement = this.options.transitionMovement;
+        }
+
+        newCoordinates = this._repositionWithinScreen(targetLeft, targetTop, tooltipWidth, tooltipHeight);
+        $(tooltip).css({
+          top: newCoordinates.y + 'px',
+          left: newCoordinates.x + 'px'
+        });
+      }
+    }, {
+      key: "_repositionWithinScreen",
+      value: function _repositionWithinScreen(x, y, width, height) {
+        var scrollLeft = M.getDocumentScrollLeft();
+        var scrollTop = M.getDocumentScrollTop();
+        var newX = x - scrollLeft;
+        var newY = y - scrollTop;
+
+        var bounding = {
+          left: newX,
+          top: newY,
+          width: width,
+          height: height
+        };
+
+        var offset = this.options.margin + this.options.transitionMovement;
+        var edges = M.checkWithinContainer(document.body, bounding, offset);
+
+        if (edges.left) {
+          newX = offset;
+        } else if (edges.right) {
+          newX -= newX + width - window.innerWidth;
+        }
+
+        if (edges.top) {
+          newY = offset;
+        } else if (edges.bottom) {
+          newY -= newY + height - window.innerHeight;
+        }
+
+        return {
+          x: newX + scrollLeft,
+          y: newY + scrollTop
+        };
+      }
+    }, {
+      key: "_animateIn",
+      value: function _animateIn() {
+        this._positionTooltip();
+        this.tooltipEl.style.visibility = 'visible';
+        anim.remove(this.tooltipEl);
+        anim({
+          targets: this.tooltipEl,
+          opacity: 1,
+          translateX: this.xMovement,
+          translateY: this.yMovement,
+          duration: this.options.inDuration,
+          easing: 'easeOutCubic'
+        });
+      }
+    }, {
+      key: "_animateOut",
+      value: function _animateOut() {
+        anim.remove(this.tooltipEl);
+        anim({
+          targets: this.tooltipEl,
+          opacity: 0,
+          translateX: 0,
+          translateY: 0,
+          duration: this.options.outDuration,
+          easing: 'easeOutCubic'
+        });
+      }
+    }, {
+      key: "_handleMouseEnter",
+      value: function _handleMouseEnter() {
+        this.isHovered = true;
+        this.isFocused = false; // Allows close of tooltip when opened by focus.
+        this.open(false);
+      }
+    }, {
+      key: "_handleMouseLeave",
+      value: function _handleMouseLeave() {
+        this.isHovered = false;
+        this.isFocused = false; // Allows close of tooltip when opened by focus.
+        this.close();
+      }
+    }, {
+      key: "_handleFocus",
+      value: function _handleFocus() {
+        if (M.tabPressed) {
+          this.isFocused = true;
+          this.open(false);
+        }
+      }
+    }, {
+      key: "_handleBlur",
+      value: function _handleBlur() {
+        this.isFocused = false;
+        this.close();
+      }
+    }, {
+      key: "_getAttributeOptions",
+      value: function _getAttributeOptions() {
+        var attributeOptions = {};
+        var tooltipTextOption = this.el.getAttribute('data-tooltip');
+        var positionOption = this.el.getAttribute('data-position');
+
+        if (tooltipTextOption) {
+          attributeOptions.html = tooltipTextOption;
+        }
+
+        if (positionOption) {
+          attributeOptions.position = positionOption;
+        }
+        return attributeOptions;
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(Tooltip.__proto__ || Object.getPrototypeOf(Tooltip), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Tooltip;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Tooltip;
+  }(Component);
+
+  M.Tooltip = Tooltip;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(Tooltip, 'tooltip', 'M_Tooltip');
+  }
+})(cash, M.anime);
+; /*!
+  * Waves v0.6.4
+  * http://fian.my.id/Waves
+  *
+  * Copyright 2014 Alfiana E. Sibuea and other contributors
+  * Released under the MIT license
+  * https://github.com/fians/Waves/blob/master/LICENSE
+  */
+
+;(function (window) {
+  'use strict';
+
+  var Waves = Waves || {};
+  var $$ = document.querySelectorAll.bind(document);
+
+  // Find exact position of element
+  function isWindow(obj) {
+    return obj !== null && obj === obj.window;
+  }
+
+  function getWindow(elem) {
+    return isWindow(elem) ? elem : elem.nodeType === 9 && elem.defaultView;
+  }
+
+  function offset(elem) {
+    var docElem,
+        win,
+        box = { top: 0, left: 0 },
+        doc = elem && elem.ownerDocument;
+
+    docElem = doc.documentElement;
+
+    if (typeof elem.getBoundingClientRect !== typeof undefined) {
+      box = elem.getBoundingClientRect();
+    }
+    win = getWindow(doc);
+    return {
+      top: box.top + win.pageYOffset - docElem.clientTop,
+      left: box.left + win.pageXOffset - docElem.clientLeft
+    };
+  }
+
+  function convertStyle(obj) {
+    var style = '';
+
+    for (var a in obj) {
+      if (obj.hasOwnProperty(a)) {
+        style += a + ':' + obj[a] + ';';
+      }
+    }
+
+    return style;
+  }
+
+  var Effect = {
+
+    // Effect delay
+    duration: 750,
+
+    show: function (e, element) {
+
+      // Disable right click
+      if (e.button === 2) {
+        return false;
+      }
+
+      var el = element || this;
+
+      // Create ripple
+      var ripple = document.createElement('div');
+      ripple.className = 'waves-ripple';
+      el.appendChild(ripple);
+
+      // Get click coordinate and element witdh
+      var pos = offset(el);
+      var relativeY = e.pageY - pos.top;
+      var relativeX = e.pageX - pos.left;
+      var scale = 'scale(' + el.clientWidth / 100 * 10 + ')';
+
+      // Support for touch devices
+      if ('touches' in e) {
+        relativeY = e.touches[0].pageY - pos.top;
+        relativeX = e.touches[0].pageX - pos.left;
+      }
+
+      // Attach data to element
+      ripple.setAttribute('data-hold', Date.now());
+      ripple.setAttribute('data-scale', scale);
+      ripple.setAttribute('data-x', relativeX);
+      ripple.setAttribute('data-y', relativeY);
+
+      // Set ripple position
+      var rippleStyle = {
+        'top': relativeY + 'px',
+        'left': relativeX + 'px'
+      };
+
+      ripple.className = ripple.className + ' waves-notransition';
+      ripple.setAttribute('style', convertStyle(rippleStyle));
+      ripple.className = ripple.className.replace('waves-notransition', '');
+
+      // Scale the ripple
+      rippleStyle['-webkit-transform'] = scale;
+      rippleStyle['-moz-transform'] = scale;
+      rippleStyle['-ms-transform'] = scale;
+      rippleStyle['-o-transform'] = scale;
+      rippleStyle.transform = scale;
+      rippleStyle.opacity = '1';
+
+      rippleStyle['-webkit-transition-duration'] = Effect.duration + 'ms';
+      rippleStyle['-moz-transition-duration'] = Effect.duration + 'ms';
+      rippleStyle['-o-transition-duration'] = Effect.duration + 'ms';
+      rippleStyle['transition-duration'] = Effect.duration + 'ms';
+
+      rippleStyle['-webkit-transition-timing-function'] = 'cubic-bezier(0.250, 0.460, 0.450, 0.940)';
+      rippleStyle['-moz-transition-timing-function'] = 'cubic-bezier(0.250, 0.460, 0.450, 0.940)';
+      rippleStyle['-o-transition-timing-function'] = 'cubic-bezier(0.250, 0.460, 0.450, 0.940)';
+      rippleStyle['transition-timing-function'] = 'cubic-bezier(0.250, 0.460, 0.450, 0.940)';
+
+      ripple.setAttribute('style', convertStyle(rippleStyle));
+    },
+
+    hide: function (e) {
+      TouchHandler.touchup(e);
+
+      var el = this;
+      var width = el.clientWidth * 1.4;
+
+      // Get first ripple
+      var ripple = null;
+      var ripples = el.getElementsByClassName('waves-ripple');
+      if (ripples.length > 0) {
+        ripple = ripples[ripples.length - 1];
+      } else {
+        return false;
+      }
+
+      var relativeX = ripple.getAttribute('data-x');
+      var relativeY = ripple.getAttribute('data-y');
+      var scale = ripple.getAttribute('data-scale');
+
+      // Get delay beetween mousedown and mouse leave
+      var diff = Date.now() - Number(ripple.getAttribute('data-hold'));
+      var delay = 350 - diff;
+
+      if (delay < 0) {
+        delay = 0;
+      }
+
+      // Fade out ripple after delay
+      setTimeout(function () {
+        var style = {
+          'top': relativeY + 'px',
+          'left': relativeX + 'px',
+          'opacity': '0',
+
+          // Duration
+          '-webkit-transition-duration': Effect.duration + 'ms',
+          '-moz-transition-duration': Effect.duration + 'ms',
+          '-o-transition-duration': Effect.duration + 'ms',
+          'transition-duration': Effect.duration + 'ms',
+          '-webkit-transform': scale,
+          '-moz-transform': scale,
+          '-ms-transform': scale,
+          '-o-transform': scale,
+          'transform': scale
+        };
+
+        ripple.setAttribute('style', convertStyle(style));
+
+        setTimeout(function () {
+          try {
+            el.removeChild(ripple);
+          } catch (e) {
+            return false;
+          }
+        }, Effect.duration);
+      }, delay);
+    },
+
+    // Little hack to make <input> can perform waves effect
+    wrapInput: function (elements) {
+      for (var a = 0; a < elements.length; a++) {
+        var el = elements[a];
+
+        if (el.tagName.toLowerCase() === 'input') {
+          var parent = el.parentNode;
+
+          // If input already have parent just pass through
+          if (parent.tagName.toLowerCase() === 'i' && parent.className.indexOf('waves-effect') !== -1) {
+            continue;
+          }
+
+          // Put element class and style to the specified parent
+          var wrapper = document.createElement('i');
+          wrapper.className = el.className + ' waves-input-wrapper';
+
+          var elementStyle = el.getAttribute('style');
+
+          if (!elementStyle) {
+            elementStyle = '';
+          }
+
+          wrapper.setAttribute('style', elementStyle);
+
+          el.className = 'waves-button-input';
+          el.removeAttribute('style');
+
+          // Put element as child
+          parent.replaceChild(wrapper, el);
+          wrapper.appendChild(el);
+        }
+      }
+    }
+  };
+
+  /**
+   * Disable mousedown event for 500ms during and after touch
+   */
+  var TouchHandler = {
+    /* uses an integer rather than bool so there's no issues with
+     * needing to clear timeouts if another touch event occurred
+     * within the 500ms. Cannot mouseup between touchstart and
+     * touchend, nor in the 500ms after touchend. */
+    touches: 0,
+    allowEvent: function (e) {
+      var allow = true;
+
+      if (e.type === 'touchstart') {
+        TouchHandler.touches += 1; //push
+      } else if (e.type === 'touchend' || e.type === 'touchcancel') {
+        setTimeout(function () {
+          if (TouchHandler.touches > 0) {
+            TouchHandler.touches -= 1; //pop after 500ms
+          }
+        }, 500);
+      } else if (e.type === 'mousedown' && TouchHandler.touches > 0) {
+        allow = false;
+      }
+
+      return allow;
+    },
+    touchup: function (e) {
+      TouchHandler.allowEvent(e);
+    }
+  };
+
+  /**
+   * Delegated click handler for .waves-effect element.
+   * returns null when .waves-effect element not in "click tree"
+   */
+  function getWavesEffectElement(e) {
+    if (TouchHandler.allowEvent(e) === false) {
+      return null;
+    }
+
+    var element = null;
+    var target = e.target || e.srcElement;
+
+    while (target.parentNode !== null) {
+      if (!(target instanceof SVGElement) && target.className.indexOf('waves-effect') !== -1) {
+        element = target;
+        break;
+      }
+      target = target.parentNode;
+    }
+    return element;
+  }
+
+  /**
+   * Bubble the click and show effect if .waves-effect elem was found
+   */
+  function showEffect(e) {
+    var element = getWavesEffectElement(e);
+
+    if (element !== null) {
+      Effect.show(e, element);
+
+      if ('ontouchstart' in window) {
+        element.addEventListener('touchend', Effect.hide, false);
+        element.addEventListener('touchcancel', Effect.hide, false);
+      }
+
+      element.addEventListener('mouseup', Effect.hide, false);
+      element.addEventListener('mouseleave', Effect.hide, false);
+      element.addEventListener('dragend', Effect.hide, false);
+    }
+  }
+
+  Waves.displayEffect = function (options) {
+    options = options || {};
+
+    if ('duration' in options) {
+      Effect.duration = options.duration;
+    }
+
+    //Wrap input inside <i> tag
+    Effect.wrapInput($$('.waves-effect'));
+
+    if ('ontouchstart' in window) {
+      document.body.addEventListener('touchstart', showEffect, false);
+    }
+
+    document.body.addEventListener('mousedown', showEffect, false);
+  };
+
+  /**
+   * Attach Waves to an input element (or any element which doesn't
+   * bubble mouseup/mousedown events).
+   *   Intended to be used with dynamically loaded forms/inputs, or
+   * where the user doesn't want a delegated click handler.
+   */
+  Waves.attach = function (element) {
+    //FUTURE: automatically add waves classes and allow users
+    // to specify them with an options param? Eg. light/classic/button
+    if (element.tagName.toLowerCase() === 'input') {
+      Effect.wrapInput([element]);
+      element = element.parentNode;
+    }
+
+    if ('ontouchstart' in window) {
+      element.addEventListener('touchstart', showEffect, false);
+    }
+
+    element.addEventListener('mousedown', showEffect, false);
+  };
+
+  window.Waves = Waves;
+
+  document.addEventListener('DOMContentLoaded', function () {
+    Waves.displayEffect();
+  }, false);
+})(window);
+;(function ($, anim) {
+  'use strict';
+
+  var _defaults = {
+    html: '',
+    displayLength: 4000,
+    inDuration: 300,
+    outDuration: 375,
+    classes: '',
+    completeCallback: null,
+    activationPercent: 0.8
+  };
+
+  var Toast = function () {
+    function Toast(options) {
+      _classCallCheck(this, Toast);
+
+      /**
+       * Options for the toast
+       * @member Toast#options
+       */
+      this.options = $.extend({}, Toast.defaults, options);
+      this.message = this.options.html;
+
+      /**
+       * Describes current pan state toast
+       * @type {Boolean}
+       */
+      this.panning = false;
+
+      /**
+       * Time remaining until toast is removed
+       */
+      this.timeRemaining = this.options.displayLength;
+
+      if (Toast._toasts.length === 0) {
+        Toast._createContainer();
+      }
+
+      // Create new toast
+      Toast._toasts.push(this);
+      var toastElement = this._createToast();
+      toastElement.M_Toast = this;
+      this.el = toastElement;
+      this.$el = $(toastElement);
+      this._animateIn();
+      this._setTimer();
+    }
+
+    _createClass(Toast, [{
+      key: "_createToast",
+
+
+      /**
+       * Create toast and append it to toast container
+       */
+      value: function _createToast() {
+        var toast = document.createElement('div');
+        toast.classList.add('toast');
+
+        // Add custom classes onto toast
+        if (!!this.options.classes.length) {
+          $(toast).addClass(this.options.classes);
+        }
+
+        // Set content
+        if (typeof HTMLElement === 'object' ? this.message instanceof HTMLElement : this.message && typeof this.message === 'object' && this.message !== null && this.message.nodeType === 1 && typeof this.message.nodeName === 'string') {
+          toast.appendChild(this.message);
+
+          // Check if it is jQuery object
+        } else if (!!this.message.jquery) {
+          $(toast).append(this.message[0]);
+
+          // Insert as html;
+        } else {
+          toast.innerHTML = this.message;
+        }
+
+        // Append toasft
+        Toast._container.appendChild(toast);
+        return toast;
+      }
+
+      /**
+       * Animate in toast
+       */
+
+    }, {
+      key: "_animateIn",
+      value: function _animateIn() {
+        // Animate toast in
+        anim({
+          targets: this.el,
+          top: 0,
+          opacity: 1,
+          duration: this.options.inDuration,
+          easing: 'easeOutCubic'
+        });
+      }
+
+      /**
+       * Create setInterval which automatically removes toast when timeRemaining >= 0
+       * has been reached
+       */
+
+    }, {
+      key: "_setTimer",
+      value: function _setTimer() {
+        var _this29 = this;
+
+        if (this.timeRemaining !== Infinity) {
+          this.counterInterval = setInterval(function () {
+            // If toast is not being dragged, decrease its time remaining
+            if (!_this29.panning) {
+              _this29.timeRemaining -= 20;
+            }
+
+            // Animate toast out
+            if (_this29.timeRemaining <= 0) {
+              _this29.dismiss();
+            }
+          }, 20);
+        }
+      }
+
+      /**
+       * Dismiss toast with animation
+       */
+
+    }, {
+      key: "dismiss",
+      value: function dismiss() {
+        var _this30 = this;
+
+        window.clearInterval(this.counterInterval);
+        var activationDistance = this.el.offsetWidth * this.options.activationPercent;
+
+        if (this.wasSwiped) {
+          this.el.style.transition = 'transform .05s, opacity .05s';
+          this.el.style.transform = "translateX(" + activationDistance + "px)";
+          this.el.style.opacity = 0;
+        }
+
+        anim({
+          targets: this.el,
+          opacity: 0,
+          marginTop: -40,
+          duration: this.options.outDuration,
+          easing: 'easeOutExpo',
+          complete: function () {
+            // Call the optional callback
+            if (typeof _this30.options.completeCallback === 'function') {
+              _this30.options.completeCallback();
+            }
+            // Remove toast from DOM
+            _this30.$el.remove();
+            Toast._toasts.splice(Toast._toasts.indexOf(_this30), 1);
+            if (Toast._toasts.length === 0) {
+              Toast._removeContainer();
+            }
+          }
+        });
+      }
+    }], [{
+      key: "getInstance",
+
+
+      /**
+       * Get Instance
+       */
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Toast;
+      }
+
+      /**
+       * Append toast container and add event handlers
+       */
+
+    }, {
+      key: "_createContainer",
+      value: function _createContainer() {
+        var container = document.createElement('div');
+        container.setAttribute('id', 'toast-container');
+
+        // Add event handler
+        container.addEventListener('touchstart', Toast._onDragStart);
+        container.addEventListener('touchmove', Toast._onDragMove);
+        container.addEventListener('touchend', Toast._onDragEnd);
+
+        container.addEventListener('mousedown', Toast._onDragStart);
+        document.addEventListener('mousemove', Toast._onDragMove);
+        document.addEventListener('mouseup', Toast._onDragEnd);
+
+        document.body.appendChild(container);
+        Toast._container = container;
+      }
+
+      /**
+       * Remove toast container and event handlers
+       */
+
+    }, {
+      key: "_removeContainer",
+      value: function _removeContainer() {
+        // Add event handler
+        document.removeEventListener('mousemove', Toast._onDragMove);
+        document.removeEventListener('mouseup', Toast._onDragEnd);
+
+        $(Toast._container).remove();
+        Toast._container = null;
+      }
+
+      /**
+       * Begin drag handler
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_onDragStart",
+      value: function _onDragStart(e) {
+        if (e.target && $(e.target).closest('.toast').length) {
+          var $toast = $(e.target).closest('.toast');
+          var toast = $toast[0].M_Toast;
+          toast.panning = true;
+          Toast._draggedToast = toast;
+          toast.el.classList.add('panning');
+          toast.el.style.transition = '';
+          toast.startingXPos = Toast._xPos(e);
+          toast.time = Date.now();
+          toast.xPos = Toast._xPos(e);
+        }
+      }
+
+      /**
+       * Drag move handler
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_onDragMove",
+      value: function _onDragMove(e) {
+        if (!!Toast._draggedToast) {
+          e.preventDefault();
+          var toast = Toast._draggedToast;
+          toast.deltaX = Math.abs(toast.xPos - Toast._xPos(e));
+          toast.xPos = Toast._xPos(e);
+          toast.velocityX = toast.deltaX / (Date.now() - toast.time);
+          toast.time = Date.now();
+
+          var totalDeltaX = toast.xPos - toast.startingXPos;
+          var activationDistance = toast.el.offsetWidth * toast.options.activationPercent;
+          toast.el.style.transform = "translateX(" + totalDeltaX + "px)";
+          toast.el.style.opacity = 1 - Math.abs(totalDeltaX / activationDistance);
+        }
+      }
+
+      /**
+       * End drag handler
+       */
+
+    }, {
+      key: "_onDragEnd",
+      value: function _onDragEnd() {
+        if (!!Toast._draggedToast) {
+          var toast = Toast._draggedToast;
+          toast.panning = false;
+          toast.el.classList.remove('panning');
+
+          var totalDeltaX = toast.xPos - toast.startingXPos;
+          var activationDistance = toast.el.offsetWidth * toast.options.activationPercent;
+          var shouldBeDismissed = Math.abs(totalDeltaX) > activationDistance || toast.velocityX > 1;
+
+          // Remove toast
+          if (shouldBeDismissed) {
+            toast.wasSwiped = true;
+            toast.dismiss();
+
+            // Animate toast back to original position
+          } else {
+            toast.el.style.transition = 'transform .2s, opacity .2s';
+            toast.el.style.transform = '';
+            toast.el.style.opacity = '';
+          }
+          Toast._draggedToast = null;
+        }
+      }
+
+      /**
+       * Get x position of mouse or touch event
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_xPos",
+      value: function _xPos(e) {
+        if (e.targetTouches && e.targetTouches.length >= 1) {
+          return e.targetTouches[0].clientX;
+        }
+        // mouse event
+        return e.clientX;
+      }
+
+      /**
+       * Remove all toasts
+       */
+
+    }, {
+      key: "dismissAll",
+      value: function dismissAll() {
+        for (var toastIndex in Toast._toasts) {
+          Toast._toasts[toastIndex].dismiss();
+        }
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Toast;
+  }();
+
+  /**
+   * @static
+   * @memberof Toast
+   * @type {Array.<Toast>}
+   */
+
+
+  Toast._toasts = [];
+
+  /**
+   * @static
+   * @memberof Toast
+   */
+  Toast._container = null;
+
+  /**
+   * @static
+   * @memberof Toast
+   * @type {Toast}
+   */
+  Toast._draggedToast = null;
+
+  M.Toast = Toast;
+  M.toast = function (options) {
+    return new Toast(options);
+  };
+})(cash, M.anime);
+;(function ($, anim) {
+  'use strict';
+
+  var _defaults = {
+    edge: 'left',
+    draggable: true,
+    inDuration: 250,
+    outDuration: 200,
+    onOpenStart: null,
+    onOpenEnd: null,
+    onCloseStart: null,
+    onCloseEnd: null,
+    preventScrolling: true
+  };
+
+  /**
+   * @class
+   */
+
+  var Sidenav = function (_Component8) {
+    _inherits(Sidenav, _Component8);
+
+    /**
+     * Construct Sidenav instance and set up overlay
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function Sidenav(el, options) {
+      _classCallCheck(this, Sidenav);
+
+      var _this31 = _possibleConstructorReturn(this, (Sidenav.__proto__ || Object.getPrototypeOf(Sidenav)).call(this, Sidenav, el, options));
+
+      _this31.el.M_Sidenav = _this31;
+      _this31.id = _this31.$el.attr('id');
+
+      /**
+       * Options for the Sidenav
+       * @member Sidenav#options
+       * @prop {String} [edge='left'] - Side of screen on which Sidenav appears
+       * @prop {Boolean} [draggable=true] - Allow swipe gestures to open/close Sidenav
+       * @prop {Number} [inDuration=250] - Length in ms of enter transition
+       * @prop {Number} [outDuration=200] - Length in ms of exit transition
+       * @prop {Function} onOpenStart - Function called when sidenav starts entering
+       * @prop {Function} onOpenEnd - Function called when sidenav finishes entering
+       * @prop {Function} onCloseStart - Function called when sidenav starts exiting
+       * @prop {Function} onCloseEnd - Function called when sidenav finishes exiting
+       */
+      _this31.options = $.extend({}, Sidenav.defaults, options);
+
+      /**
+       * Describes open/close state of Sidenav
+       * @type {Boolean}
+       */
+      _this31.isOpen = false;
+
+      /**
+       * Describes if Sidenav is fixed
+       * @type {Boolean}
+       */
+      _this31.isFixed = _this31.el.classList.contains('sidenav-fixed');
+
+      /**
+       * Describes if Sidenav is being draggeed
+       * @type {Boolean}
+       */
+      _this31.isDragged = false;
+
+      // Window size variables for window resize checks
+      _this31.lastWindowWidth = window.innerWidth;
+      _this31.lastWindowHeight = window.innerHeight;
+
+      _this31._createOverlay();
+      _this31._createDragTarget();
+      _this31._setupEventHandlers();
+      _this31._setupClasses();
+      _this31._setupFixed();
+
+      Sidenav._sidenavs.push(_this31);
+      return _this31;
+    }
+
+    _createClass(Sidenav, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        this._removeEventHandlers();
+        this._enableBodyScrolling();
+        this._overlay.parentNode.removeChild(this._overlay);
+        this.dragTarget.parentNode.removeChild(this.dragTarget);
+        this.el.M_Sidenav = undefined;
+        this.el.style.transform = '';
+
+        var index = Sidenav._sidenavs.indexOf(this);
+        if (index >= 0) {
+          Sidenav._sidenavs.splice(index, 1);
+        }
+      }
+    }, {
+      key: "_createOverlay",
+      value: function _createOverlay() {
+        var overlay = document.createElement('div');
+        this._closeBound = this.close.bind(this);
+        overlay.classList.add('sidenav-overlay');
+
+        overlay.addEventListener('click', this._closeBound);
+
+        document.body.appendChild(overlay);
+        this._overlay = overlay;
+      }
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        if (Sidenav._sidenavs.length === 0) {
+          document.body.addEventListener('click', this._handleTriggerClick);
+        }
+
+        this._handleDragTargetDragBound = this._handleDragTargetDrag.bind(this);
+        this._handleDragTargetReleaseBound = this._handleDragTargetRelease.bind(this);
+        this._handleCloseDragBound = this._handleCloseDrag.bind(this);
+        this._handleCloseReleaseBound = this._handleCloseRelease.bind(this);
+        this._handleCloseTriggerClickBound = this._handleCloseTriggerClick.bind(this);
+
+        this.dragTarget.addEventListener('touchmove', this._handleDragTargetDragBound);
+        this.dragTarget.addEventListener('touchend', this._handleDragTargetReleaseBound);
+        this._overlay.addEventListener('touchmove', this._handleCloseDragBound);
+        this._overlay.addEventListener('touchend', this._handleCloseReleaseBound);
+        this.el.addEventListener('touchmove', this._handleCloseDragBound);
+        this.el.addEventListener('touchend', this._handleCloseReleaseBound);
+        this.el.addEventListener('click', this._handleCloseTriggerClickBound);
+
+        // Add resize for side nav fixed
+        if (this.isFixed) {
+          this._handleWindowResizeBound = this._handleWindowResize.bind(this);
+          window.addEventListener('resize', this._handleWindowResizeBound);
+        }
+      }
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        if (Sidenav._sidenavs.length === 1) {
+          document.body.removeEventListener('click', this._handleTriggerClick);
+        }
+
+        this.dragTarget.removeEventListener('touchmove', this._handleDragTargetDragBound);
+        this.dragTarget.removeEventListener('touchend', this._handleDragTargetReleaseBound);
+        this._overlay.removeEventListener('touchmove', this._handleCloseDragBound);
+        this._overlay.removeEventListener('touchend', this._handleCloseReleaseBound);
+        this.el.removeEventListener('touchmove', this._handleCloseDragBound);
+        this.el.removeEventListener('touchend', this._handleCloseReleaseBound);
+        this.el.removeEventListener('click', this._handleCloseTriggerClickBound);
+
+        // Remove resize for side nav fixed
+        if (this.isFixed) {
+          window.removeEventListener('resize', this._handleWindowResizeBound);
+        }
+      }
+
+      /**
+       * Handle Trigger Click
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleTriggerClick",
+      value: function _handleTriggerClick(e) {
+        var $trigger = $(e.target).closest('.sidenav-trigger');
+        if (e.target && $trigger.length) {
+          var sidenavId = M.getIdFromTrigger($trigger[0]);
+
+          var sidenavInstance = document.getElementById(sidenavId).M_Sidenav;
+          if (sidenavInstance) {
+            sidenavInstance.open($trigger);
+          }
+          e.preventDefault();
+        }
+      }
+
+      /**
+       * Set variables needed at the beggining of drag
+       * and stop any current transition.
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_startDrag",
+      value: function _startDrag(e) {
+        var clientX = e.targetTouches[0].clientX;
+        this.isDragged = true;
+        this._startingXpos = clientX;
+        this._xPos = this._startingXpos;
+        this._time = Date.now();
+        this._width = this.el.getBoundingClientRect().width;
+        this._overlay.style.display = 'block';
+        this._initialScrollTop = this.isOpen ? this.el.scrollTop : M.getDocumentScrollTop();
+        this._verticallyScrolling = false;
+        anim.remove(this.el);
+        anim.remove(this._overlay);
+      }
+
+      /**
+       * Set variables needed at each drag move update tick
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_dragMoveUpdate",
+      value: function _dragMoveUpdate(e) {
+        var clientX = e.targetTouches[0].clientX;
+        var currentScrollTop = this.isOpen ? this.el.scrollTop : M.getDocumentScrollTop();
+        this.deltaX = Math.abs(this._xPos - clientX);
+        this._xPos = clientX;
+        this.velocityX = this.deltaX / (Date.now() - this._time);
+        this._time = Date.now();
+        if (this._initialScrollTop !== currentScrollTop) {
+          this._verticallyScrolling = true;
+        }
+      }
+
+      /**
+       * Handles Dragging of Sidenav
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleDragTargetDrag",
+      value: function _handleDragTargetDrag(e) {
+        // Check if draggable
+        if (!this.options.draggable || this._isCurrentlyFixed() || this._verticallyScrolling) {
+          return;
+        }
+
+        // If not being dragged, set initial drag start variables
+        if (!this.isDragged) {
+          this._startDrag(e);
+        }
+
+        // Run touchmove updates
+        this._dragMoveUpdate(e);
+
+        // Calculate raw deltaX
+        var totalDeltaX = this._xPos - this._startingXpos;
+
+        // dragDirection is the attempted user drag direction
+        var dragDirection = totalDeltaX > 0 ? 'right' : 'left';
+
+        // Don't allow totalDeltaX to exceed Sidenav width or be dragged in the opposite direction
+        totalDeltaX = Math.min(this._width, Math.abs(totalDeltaX));
+        if (this.options.edge === dragDirection) {
+          totalDeltaX = 0;
+        }
+
+        /**
+         * transformX is the drag displacement
+         * transformPrefix is the initial transform placement
+         * Invert values if Sidenav is right edge
+         */
+        var transformX = totalDeltaX;
+        var transformPrefix = 'translateX(-100%)';
+        if (this.options.edge === 'right') {
+          transformPrefix = 'translateX(100%)';
+          transformX = -transformX;
+        }
+
+        // Calculate open/close percentage of sidenav, with open = 1 and close = 0
+        this.percentOpen = Math.min(1, totalDeltaX / this._width);
+
+        // Set transform and opacity styles
+        this.el.style.transform = transformPrefix + " translateX(" + transformX + "px)";
+        this._overlay.style.opacity = this.percentOpen;
+      }
+
+      /**
+       * Handle Drag Target Release
+       */
+
+    }, {
+      key: "_handleDragTargetRelease",
+      value: function _handleDragTargetRelease() {
+        if (this.isDragged) {
+          if (this.percentOpen > 0.2) {
+            this.open();
+          } else {
+            this._animateOut();
+          }
+
+          this.isDragged = false;
+          this._verticallyScrolling = false;
+        }
+      }
+
+      /**
+       * Handle Close Drag
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleCloseDrag",
+      value: function _handleCloseDrag(e) {
+        if (this.isOpen) {
+          // Check if draggable
+          if (!this.options.draggable || this._isCurrentlyFixed() || this._verticallyScrolling) {
+            return;
+          }
+
+          // If not being dragged, set initial drag start variables
+          if (!this.isDragged) {
+            this._startDrag(e);
+          }
+
+          // Run touchmove updates
+          this._dragMoveUpdate(e);
+
+          // Calculate raw deltaX
+          var totalDeltaX = this._xPos - this._startingXpos;
+
+          // dragDirection is the attempted user drag direction
+          var dragDirection = totalDeltaX > 0 ? 'right' : 'left';
+
+          // Don't allow totalDeltaX to exceed Sidenav width or be dragged in the opposite direction
+          totalDeltaX = Math.min(this._width, Math.abs(totalDeltaX));
+          if (this.options.edge !== dragDirection) {
+            totalDeltaX = 0;
+          }
+
+          var transformX = -totalDeltaX;
+          if (this.options.edge === 'right') {
+            transformX = -transformX;
+          }
+
+          // Calculate open/close percentage of sidenav, with open = 1 and close = 0
+          this.percentOpen = Math.min(1, 1 - totalDeltaX / this._width);
+
+          // Set transform and opacity styles
+          this.el.style.transform = "translateX(" + transformX + "px)";
+          this._overlay.style.opacity = this.percentOpen;
+        }
+      }
+
+      /**
+       * Handle Close Release
+       */
+
+    }, {
+      key: "_handleCloseRelease",
+      value: function _handleCloseRelease() {
+        if (this.isOpen && this.isDragged) {
+          if (this.percentOpen > 0.8) {
+            this._animateIn();
+          } else {
+            this.close();
+          }
+
+          this.isDragged = false;
+          this._verticallyScrolling = false;
+        }
+      }
+
+      /**
+       * Handles closing of Sidenav when element with class .sidenav-close
+       */
+
+    }, {
+      key: "_handleCloseTriggerClick",
+      value: function _handleCloseTriggerClick(e) {
+        var $closeTrigger = $(e.target).closest('.sidenav-close');
+        if ($closeTrigger.length && !this._isCurrentlyFixed()) {
+          this.close();
+        }
+      }
+
+      /**
+       * Handle Window Resize
+       */
+
+    }, {
+      key: "_handleWindowResize",
+      value: function _handleWindowResize() {
+        // Only handle horizontal resizes
+        if (this.lastWindowWidth !== window.innerWidth) {
+          if (window.innerWidth > 992) {
+            this.open();
+          } else {
+            this.close();
+          }
+        }
+
+        this.lastWindowWidth = window.innerWidth;
+        this.lastWindowHeight = window.innerHeight;
+      }
+    }, {
+      key: "_setupClasses",
+      value: function _setupClasses() {
+        if (this.options.edge === 'right') {
+          this.el.classList.add('right-aligned');
+          this.dragTarget.classList.add('right-aligned');
+        }
+      }
+    }, {
+      key: "_removeClasses",
+      value: function _removeClasses() {
+        this.el.classList.remove('right-aligned');
+        this.dragTarget.classList.remove('right-aligned');
+      }
+    }, {
+      key: "_setupFixed",
+      value: function _setupFixed() {
+        if (this._isCurrentlyFixed()) {
+          this.open();
+        }
+      }
+    }, {
+      key: "_isCurrentlyFixed",
+      value: function _isCurrentlyFixed() {
+        return this.isFixed && window.innerWidth > 992;
+      }
+    }, {
+      key: "_createDragTarget",
+      value: function _createDragTarget() {
+        var dragTarget = document.createElement('div');
+        dragTarget.classList.add('drag-target');
+        document.body.appendChild(dragTarget);
+        this.dragTarget = dragTarget;
+      }
+    }, {
+      key: "_preventBodyScrolling",
+      value: function _preventBodyScrolling() {
+        var body = document.body;
+        body.style.overflow = 'hidden';
+      }
+    }, {
+      key: "_enableBodyScrolling",
+      value: function _enableBodyScrolling() {
+        var body = document.body;
+        body.style.overflow = '';
+      }
+    }, {
+      key: "open",
+      value: function open() {
+        if (this.isOpen === true) {
+          return;
+        }
+
+        this.isOpen = true;
+
+        // Run onOpenStart callback
+        if (typeof this.options.onOpenStart === 'function') {
+          this.options.onOpenStart.call(this, this.el);
+        }
+
+        // Handle fixed Sidenav
+        if (this._isCurrentlyFixed()) {
+          anim.remove(this.el);
+          anim({
+            targets: this.el,
+            translateX: 0,
+            duration: 0,
+            easing: 'easeOutQuad'
+          });
+          this._enableBodyScrolling();
+          this._overlay.style.display = 'none';
+
+          // Handle non-fixed Sidenav
+        } else {
+          if (this.options.preventScrolling) {
+            this._preventBodyScrolling();
+          }
+
+          if (!this.isDragged || this.percentOpen != 1) {
+            this._animateIn();
+          }
+        }
+      }
+    }, {
+      key: "close",
+      value: function close() {
+        if (this.isOpen === false) {
+          return;
+        }
+
+        this.isOpen = false;
+
+        // Run onCloseStart callback
+        if (typeof this.options.onCloseStart === 'function') {
+          this.options.onCloseStart.call(this, this.el);
+        }
+
+        // Handle fixed Sidenav
+        if (this._isCurrentlyFixed()) {
+          var transformX = this.options.edge === 'left' ? '-105%' : '105%';
+          this.el.style.transform = "translateX(" + transformX + ")";
+
+          // Handle non-fixed Sidenav
+        } else {
+          this._enableBodyScrolling();
+
+          if (!this.isDragged || this.percentOpen != 0) {
+            this._animateOut();
+          } else {
+            this._overlay.style.display = 'none';
+          }
+        }
+      }
+    }, {
+      key: "_animateIn",
+      value: function _animateIn() {
+        this._animateSidenavIn();
+        this._animateOverlayIn();
+      }
+    }, {
+      key: "_animateSidenavIn",
+      value: function _animateSidenavIn() {
+        var _this32 = this;
+
+        var slideOutPercent = this.options.edge === 'left' ? -1 : 1;
+        if (this.isDragged) {
+          slideOutPercent = this.options.edge === 'left' ? slideOutPercent + this.percentOpen : slideOutPercent - this.percentOpen;
+        }
+
+        anim.remove(this.el);
+        anim({
+          targets: this.el,
+          translateX: [slideOutPercent * 100 + "%", 0],
+          duration: this.options.inDuration,
+          easing: 'easeOutQuad',
+          complete: function () {
+            // Run onOpenEnd callback
+            if (typeof _this32.options.onOpenEnd === 'function') {
+              _this32.options.onOpenEnd.call(_this32, _this32.el);
+            }
+          }
+        });
+      }
+    }, {
+      key: "_animateOverlayIn",
+      value: function _animateOverlayIn() {
+        var start = 0;
+        if (this.isDragged) {
+          start = this.percentOpen;
+        } else {
+          $(this._overlay).css({
+            display: 'block'
+          });
+        }
+
+        anim.remove(this._overlay);
+        anim({
+          targets: this._overlay,
+          opacity: [start, 1],
+          duration: this.options.inDuration,
+          easing: 'easeOutQuad'
+        });
+      }
+    }, {
+      key: "_animateOut",
+      value: function _animateOut() {
+        this._animateSidenavOut();
+        this._animateOverlayOut();
+      }
+    }, {
+      key: "_animateSidenavOut",
+      value: function _animateSidenavOut() {
+        var _this33 = this;
+
+        var endPercent = this.options.edge === 'left' ? -1 : 1;
+        var slideOutPercent = 0;
+        if (this.isDragged) {
+          slideOutPercent = this.options.edge === 'left' ? endPercent + this.percentOpen : endPercent - this.percentOpen;
+        }
+
+        anim.remove(this.el);
+        anim({
+          targets: this.el,
+          translateX: [slideOutPercent * 100 + "%", endPercent * 105 + "%"],
+          duration: this.options.outDuration,
+          easing: 'easeOutQuad',
+          complete: function () {
+            // Run onOpenEnd callback
+            if (typeof _this33.options.onCloseEnd === 'function') {
+              _this33.options.onCloseEnd.call(_this33, _this33.el);
+            }
+          }
+        });
+      }
+    }, {
+      key: "_animateOverlayOut",
+      value: function _animateOverlayOut() {
+        var _this34 = this;
+
+        anim.remove(this._overlay);
+        anim({
+          targets: this._overlay,
+          opacity: 0,
+          duration: this.options.outDuration,
+          easing: 'easeOutQuad',
+          complete: function () {
+            $(_this34._overlay).css('display', 'none');
+          }
+        });
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(Sidenav.__proto__ || Object.getPrototypeOf(Sidenav), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Sidenav;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Sidenav;
+  }(Component);
+
+  /**
+   * @static
+   * @memberof Sidenav
+   * @type {Array.<Sidenav>}
+   */
+
+
+  Sidenav._sidenavs = [];
+
+  M.Sidenav = Sidenav;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(Sidenav, 'sidenav', 'M_Sidenav');
+  }
+})(cash, M.anime);
+;(function ($, anim) {
+  'use strict';
+
+  var _defaults = {
+    throttle: 100,
+    scrollOffset: 200, // offset - 200 allows elements near bottom of page to scroll
+    activeClass: 'active',
+    getActiveElement: function (id) {
+      return 'a[href="#' + id + '"]';
+    }
+  };
+
+  /**
+   * @class
+   *
+   */
+
+  var ScrollSpy = function (_Component9) {
+    _inherits(ScrollSpy, _Component9);
+
+    /**
+     * Construct ScrollSpy instance
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function ScrollSpy(el, options) {
+      _classCallCheck(this, ScrollSpy);
+
+      var _this35 = _possibleConstructorReturn(this, (ScrollSpy.__proto__ || Object.getPrototypeOf(ScrollSpy)).call(this, ScrollSpy, el, options));
+
+      _this35.el.M_ScrollSpy = _this35;
+
+      /**
+       * Options for the modal
+       * @member Modal#options
+       * @prop {Number} [throttle=100] - Throttle of scroll handler
+       * @prop {Number} [scrollOffset=200] - Offset for centering element when scrolled to
+       * @prop {String} [activeClass='active'] - Class applied to active elements
+       * @prop {Function} [getActiveElement] - Used to find active element
+       */
+      _this35.options = $.extend({}, ScrollSpy.defaults, options);
+
+      // setup
+      ScrollSpy._elements.push(_this35);
+      ScrollSpy._count++;
+      ScrollSpy._increment++;
+      _this35.tickId = -1;
+      _this35.id = ScrollSpy._increment;
+      _this35._setupEventHandlers();
+      _this35._handleWindowScroll();
+      return _this35;
+    }
+
+    _createClass(ScrollSpy, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        ScrollSpy._elements.splice(ScrollSpy._elements.indexOf(this), 1);
+        ScrollSpy._elementsInView.splice(ScrollSpy._elementsInView.indexOf(this), 1);
+        ScrollSpy._visibleElements.splice(ScrollSpy._visibleElements.indexOf(this.$el), 1);
+        ScrollSpy._count--;
+        this._removeEventHandlers();
+        $(this.options.getActiveElement(this.$el.attr('id'))).removeClass(this.options.activeClass);
+        this.el.M_ScrollSpy = undefined;
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        var throttledResize = M.throttle(this._handleWindowScroll, 200);
+        this._handleThrottledResizeBound = throttledResize.bind(this);
+        this._handleWindowScrollBound = this._handleWindowScroll.bind(this);
+        if (ScrollSpy._count === 1) {
+          window.addEventListener('scroll', this._handleWindowScrollBound);
+          window.addEventListener('resize', this._handleThrottledResizeBound);
+          document.body.addEventListener('click', this._handleTriggerClick);
+        }
+      }
+
+      /**
+       * Remove Event Handlers
+       */
+
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        if (ScrollSpy._count === 0) {
+          window.removeEventListener('scroll', this._handleWindowScrollBound);
+          window.removeEventListener('resize', this._handleThrottledResizeBound);
+          document.body.removeEventListener('click', this._handleTriggerClick);
+        }
+      }
+
+      /**
+       * Handle Trigger Click
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleTriggerClick",
+      value: function _handleTriggerClick(e) {
+        var $trigger = $(e.target);
+        for (var i = ScrollSpy._elements.length - 1; i >= 0; i--) {
+          var scrollspy = ScrollSpy._elements[i];
+          if ($trigger.is('a[href="#' + scrollspy.$el.attr('id') + '"]')) {
+            e.preventDefault();
+            var offset = scrollspy.$el.offset().top + 1;
+
+            anim({
+              targets: [document.documentElement, document.body],
+              scrollTop: offset - scrollspy.options.scrollOffset,
+              duration: 400,
+              easing: 'easeOutCubic'
+            });
+            break;
+          }
+        }
+      }
+
+      /**
+       * Handle Window Scroll
+       */
+
+    }, {
+      key: "_handleWindowScroll",
+      value: function _handleWindowScroll() {
+        // unique tick id
+        ScrollSpy._ticks++;
+
+        // viewport rectangle
+        var top = M.getDocumentScrollTop(),
+            left = M.getDocumentScrollLeft(),
+            right = left + window.innerWidth,
+            bottom = top + window.innerHeight;
+
+        // determine which elements are in view
+        var intersections = ScrollSpy._findElements(top, right, bottom, left);
+        for (var i = 0; i < intersections.length; i++) {
+          var scrollspy = intersections[i];
+          var lastTick = scrollspy.tickId;
+          if (lastTick < 0) {
+            // entered into view
+            scrollspy._enter();
+          }
+
+          // update tick id
+          scrollspy.tickId = ScrollSpy._ticks;
+        }
+
+        for (var _i = 0; _i < ScrollSpy._elementsInView.length; _i++) {
+          var _scrollspy = ScrollSpy._elementsInView[_i];
+          var _lastTick = _scrollspy.tickId;
+          if (_lastTick >= 0 && _lastTick !== ScrollSpy._ticks) {
+            // exited from view
+            _scrollspy._exit();
+            _scrollspy.tickId = -1;
+          }
+        }
+
+        // remember elements in view for next tick
+        ScrollSpy._elementsInView = intersections;
+      }
+
+      /**
+       * Find elements that are within the boundary
+       * @param {number} top
+       * @param {number} right
+       * @param {number} bottom
+       * @param {number} left
+       * @return {Array.<ScrollSpy>}   A collection of elements
+       */
+
+    }, {
+      key: "_enter",
+      value: function _enter() {
+        ScrollSpy._visibleElements = ScrollSpy._visibleElements.filter(function (value) {
+          return value.height() != 0;
+        });
+
+        if (ScrollSpy._visibleElements[0]) {
+          $(this.options.getActiveElement(ScrollSpy._visibleElements[0].attr('id'))).removeClass(this.options.activeClass);
+          if (ScrollSpy._visibleElements[0][0].M_ScrollSpy && this.id < ScrollSpy._visibleElements[0][0].M_ScrollSpy.id) {
+            ScrollSpy._visibleElements.unshift(this.$el);
+          } else {
+            ScrollSpy._visibleElements.push(this.$el);
+          }
+        } else {
+          ScrollSpy._visibleElements.push(this.$el);
+        }
+
+        $(this.options.getActiveElement(ScrollSpy._visibleElements[0].attr('id'))).addClass(this.options.activeClass);
+      }
+    }, {
+      key: "_exit",
+      value: function _exit() {
+        var _this36 = this;
+
+        ScrollSpy._visibleElements = ScrollSpy._visibleElements.filter(function (value) {
+          return value.height() != 0;
+        });
+
+        if (ScrollSpy._visibleElements[0]) {
+          $(this.options.getActiveElement(ScrollSpy._visibleElements[0].attr('id'))).removeClass(this.options.activeClass);
+
+          ScrollSpy._visibleElements = ScrollSpy._visibleElements.filter(function (el) {
+            return el.attr('id') != _this36.$el.attr('id');
+          });
+          if (ScrollSpy._visibleElements[0]) {
+            // Check if empty
+            $(this.options.getActiveElement(ScrollSpy._visibleElements[0].attr('id'))).addClass(this.options.activeClass);
+          }
+        }
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(ScrollSpy.__proto__ || Object.getPrototypeOf(ScrollSpy), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_ScrollSpy;
+      }
+    }, {
+      key: "_findElements",
+      value: function _findElements(top, right, bottom, left) {
+        var hits = [];
+        for (var i = 0; i < ScrollSpy._elements.length; i++) {
+          var scrollspy = ScrollSpy._elements[i];
+          var currTop = top + scrollspy.options.scrollOffset || 200;
+
+          if (scrollspy.$el.height() > 0) {
+            var elTop = scrollspy.$el.offset().top,
+                elLeft = scrollspy.$el.offset().left,
+                elRight = elLeft + scrollspy.$el.width(),
+                elBottom = elTop + scrollspy.$el.height();
+
+            var isIntersect = !(elLeft > right || elRight < left || elTop > bottom || elBottom < currTop);
+
+            if (isIntersect) {
+              hits.push(scrollspy);
+            }
+          }
+        }
+        return hits;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return ScrollSpy;
+  }(Component);
+
+  /**
+   * @static
+   * @memberof ScrollSpy
+   * @type {Array.<ScrollSpy>}
+   */
+
+
+  ScrollSpy._elements = [];
+
+  /**
+   * @static
+   * @memberof ScrollSpy
+   * @type {Array.<ScrollSpy>}
+   */
+  ScrollSpy._elementsInView = [];
+
+  /**
+   * @static
+   * @memberof ScrollSpy
+   * @type {Array.<cash>}
+   */
+  ScrollSpy._visibleElements = [];
+
+  /**
+   * @static
+   * @memberof ScrollSpy
+   */
+  ScrollSpy._count = 0;
+
+  /**
+   * @static
+   * @memberof ScrollSpy
+   */
+  ScrollSpy._increment = 0;
+
+  /**
+   * @static
+   * @memberof ScrollSpy
+   */
+  ScrollSpy._ticks = 0;
+
+  M.ScrollSpy = ScrollSpy;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(ScrollSpy, 'scrollSpy', 'M_ScrollSpy');
+  }
+})(cash, M.anime);
+;(function ($) {
+  'use strict';
+
+  var _defaults = {
+    data: {}, // Autocomplete data set
+    limit: Infinity, // Limit of results the autocomplete shows
+    onAutocomplete: null, // Callback for when autocompleted
+    minLength: 1, // Min characters before autocomplete starts
+    sortFunction: function (a, b, inputString) {
+      // Sort function for sorting autocomplete results
+      return a.indexOf(inputString) - b.indexOf(inputString);
+    }
+  };
+
+  /**
+   * @class
+   *
+   */
+
+  var Autocomplete = function (_Component10) {
+    _inherits(Autocomplete, _Component10);
+
+    /**
+     * Construct Autocomplete instance
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function Autocomplete(el, options) {
+      _classCallCheck(this, Autocomplete);
+
+      var _this37 = _possibleConstructorReturn(this, (Autocomplete.__proto__ || Object.getPrototypeOf(Autocomplete)).call(this, Autocomplete, el, options));
+
+      _this37.el.M_Autocomplete = _this37;
+
+      /**
+       * Options for the autocomplete
+       * @member Autocomplete#options
+       * @prop {Number} duration
+       * @prop {Number} dist
+       * @prop {number} shift
+       * @prop {number} padding
+       * @prop {Boolean} fullWidth
+       * @prop {Boolean} indicators
+       * @prop {Boolean} noWrap
+       * @prop {Function} onCycleTo
+       */
+      _this37.options = $.extend({}, Autocomplete.defaults, options);
+
+      // Setup
+      _this37.isOpen = false;
+      _this37.count = 0;
+      _this37.activeIndex = -1;
+      _this37.oldVal;
+      _this37.$inputField = _this37.$el.closest('.input-field');
+      _this37.$active = $();
+      _this37._mousedown = false;
+      _this37._setupDropdown();
+
+      _this37._setupEventHandlers();
+      return _this37;
+    }
+
+    _createClass(Autocomplete, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        this._removeEventHandlers();
+        this._removeDropdown();
+        this.el.M_Autocomplete = undefined;
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        this._handleInputBlurBound = this._handleInputBlur.bind(this);
+        this._handleInputKeyupAndFocusBound = this._handleInputKeyupAndFocus.bind(this);
+        this._handleInputKeydownBound = this._handleInputKeydown.bind(this);
+        this._handleInputClickBound = this._handleInputClick.bind(this);
+        this._handleContainerMousedownAndTouchstartBound = this._handleContainerMousedownAndTouchstart.bind(this);
+        this._handleContainerMouseupAndTouchendBound = this._handleContainerMouseupAndTouchend.bind(this);
+
+        this.el.addEventListener('blur', this._handleInputBlurBound);
+        this.el.addEventListener('keyup', this._handleInputKeyupAndFocusBound);
+        this.el.addEventListener('focus', this._handleInputKeyupAndFocusBound);
+        this.el.addEventListener('keydown', this._handleInputKeydownBound);
+        this.el.addEventListener('click', this._handleInputClickBound);
+        this.container.addEventListener('mousedown', this._handleContainerMousedownAndTouchstartBound);
+        this.container.addEventListener('mouseup', this._handleContainerMouseupAndTouchendBound);
+
+        if (typeof window.ontouchstart !== 'undefined') {
+          this.container.addEventListener('touchstart', this._handleContainerMousedownAndTouchstartBound);
+          this.container.addEventListener('touchend', this._handleContainerMouseupAndTouchendBound);
+        }
+      }
+
+      /**
+       * Remove Event Handlers
+       */
+
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        this.el.removeEventListener('blur', this._handleInputBlurBound);
+        this.el.removeEventListener('keyup', this._handleInputKeyupAndFocusBound);
+        this.el.removeEventListener('focus', this._handleInputKeyupAndFocusBound);
+        this.el.removeEventListener('keydown', this._handleInputKeydownBound);
+        this.el.removeEventListener('click', this._handleInputClickBound);
+        this.container.removeEventListener('mousedown', this._handleContainerMousedownAndTouchstartBound);
+        this.container.removeEventListener('mouseup', this._handleContainerMouseupAndTouchendBound);
+
+        if (typeof window.ontouchstart !== 'undefined') {
+          this.container.removeEventListener('touchstart', this._handleContainerMousedownAndTouchstartBound);
+          this.container.removeEventListener('touchend', this._handleContainerMouseupAndTouchendBound);
+        }
+      }
+
+      /**
+       * Setup dropdown
+       */
+
+    }, {
+      key: "_setupDropdown",
+      value: function _setupDropdown() {
+        var _this38 = this;
+
+        this.container = document.createElement('ul');
+        this.container.id = "autocomplete-options-" + M.guid();
+        $(this.container).addClass('autocomplete-content dropdown-content');
+        this.$inputField.append(this.container);
+        this.el.setAttribute('data-target', this.container.id);
+
+        this.dropdown = M.Dropdown.init(this.el, {
+          autoFocus: false,
+          closeOnClick: false,
+          coverTrigger: false,
+          onItemClick: function (itemEl) {
+            _this38.selectOption($(itemEl));
+          }
+        });
+
+        // Sketchy removal of dropdown click handler
+        this.el.removeEventListener('click', this.dropdown._handleClickBound);
+      }
+
+      /**
+       * Remove dropdown
+       */
+
+    }, {
+      key: "_removeDropdown",
+      value: function _removeDropdown() {
+        this.container.parentNode.removeChild(this.container);
+      }
+
+      /**
+       * Handle Input Blur
+       */
+
+    }, {
+      key: "_handleInputBlur",
+      value: function _handleInputBlur() {
+        if (!this._mousedown) {
+          this.close();
+          this._resetAutocomplete();
+        }
+      }
+
+      /**
+       * Handle Input Keyup and Focus
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleInputKeyupAndFocus",
+      value: function _handleInputKeyupAndFocus(e) {
+        if (e.type === 'keyup') {
+          Autocomplete._keydown = false;
+        }
+
+        this.count = 0;
+        var val = this.el.value.toLowerCase();
+
+        // Don't capture enter or arrow key usage.
+        if (e.keyCode === 13 || e.keyCode === 38 || e.keyCode === 40) {
+          return;
+        }
+
+        // Check if the input isn't empty
+        // Check if focus triggered by tab
+        if (this.oldVal !== val && (M.tabPressed || e.type !== 'focus')) {
+          this.open();
+        }
+
+        // Update oldVal
+        this.oldVal = val;
+      }
+
+      /**
+       * Handle Input Keydown
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleInputKeydown",
+      value: function _handleInputKeydown(e) {
+        Autocomplete._keydown = true;
+
+        // Arrow keys and enter key usage
+        var keyCode = e.keyCode,
+            liElement = void 0,
+            numItems = $(this.container).children('li').length;
+
+        // select element on Enter
+        if (keyCode === M.keys.ENTER && this.activeIndex >= 0) {
+          liElement = $(this.container).children('li').eq(this.activeIndex);
+          if (liElement.length) {
+            this.selectOption(liElement);
+            e.preventDefault();
+          }
+          return;
+        }
+
+        // Capture up and down key
+        if (keyCode === M.keys.ARROW_UP || keyCode === M.keys.ARROW_DOWN) {
+          e.preventDefault();
+
+          if (keyCode === M.keys.ARROW_UP && this.activeIndex > 0) {
+            this.activeIndex--;
+          }
+
+          if (keyCode === M.keys.ARROW_DOWN && this.activeIndex < numItems - 1) {
+            this.activeIndex++;
+          }
+
+          this.$active.removeClass('active');
+          if (this.activeIndex >= 0) {
+            this.$active = $(this.container).children('li').eq(this.activeIndex);
+            this.$active.addClass('active');
+          }
+        }
+      }
+
+      /**
+       * Handle Input Click
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleInputClick",
+      value: function _handleInputClick(e) {
+        this.open();
+      }
+
+      /**
+       * Handle Container Mousedown and Touchstart
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleContainerMousedownAndTouchstart",
+      value: function _handleContainerMousedownAndTouchstart(e) {
+        this._mousedown = true;
+      }
+
+      /**
+       * Handle Container Mouseup and Touchend
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleContainerMouseupAndTouchend",
+      value: function _handleContainerMouseupAndTouchend(e) {
+        this._mousedown = false;
+      }
+
+      /**
+       * Highlight partial match
+       */
+
+    }, {
+      key: "_highlight",
+      value: function _highlight(string, $el) {
+        var img = $el.find('img');
+        var matchStart = $el.text().toLowerCase().indexOf('' + string.toLowerCase() + ''),
+            matchEnd = matchStart + string.length - 1,
+            beforeMatch = $el.text().slice(0, matchStart),
+            matchText = $el.text().slice(matchStart, matchEnd + 1),
+            afterMatch = $el.text().slice(matchEnd + 1);
+        $el.html("<span>" + beforeMatch + "<span class='highlight'>" + matchText + "</span>" + afterMatch + "</span>");
+        if (img.length) {
+          $el.prepend(img);
+        }
+      }
+
+      /**
+       * Reset current element position
+       */
+
+    }, {
+      key: "_resetCurrentElement",
+      value: function _resetCurrentElement() {
+        this.activeIndex = -1;
+        this.$active.removeClass('active');
+      }
+
+      /**
+       * Reset autocomplete elements
+       */
+
+    }, {
+      key: "_resetAutocomplete",
+      value: function _resetAutocomplete() {
+        $(this.container).empty();
+        this._resetCurrentElement();
+        this.oldVal = null;
+        this.isOpen = false;
+        this._mousedown = false;
+      }
+
+      /**
+       * Select autocomplete option
+       * @param {Element} el  Autocomplete option list item element
+       */
+
+    }, {
+      key: "selectOption",
+      value: function selectOption(el) {
+        var text = el.text().trim();
+        this.el.value = text;
+        this.$el.trigger('change');
+        this._resetAutocomplete();
+        this.close();
+
+        // Handle onAutocomplete callback.
+        if (typeof this.options.onAutocomplete === 'function') {
+          this.options.onAutocomplete.call(this, text);
+        }
+      }
+
+      /**
+       * Render dropdown content
+       * @param {Object} data  data set
+       * @param {String} val  current input value
+       */
+
+    }, {
+      key: "_renderDropdown",
+      value: function _renderDropdown(data, val) {
+        var _this39 = this;
+
+        this._resetAutocomplete();
+
+        var matchingData = [];
+
+        // Gather all matching data
+        for (var key in data) {
+          if (data.hasOwnProperty(key) && key.toLowerCase().indexOf(val) !== -1) {
+            // Break if past limit
+            if (this.count >= this.options.limit) {
+              break;
+            }
+
+            var entry = {
+              data: data[key],
+              key: key
+            };
+            matchingData.push(entry);
+
+            this.count++;
+          }
+        }
+
+        // Sort
+        if (this.options.sortFunction) {
+          var sortFunctionBound = function (a, b) {
+            return _this39.options.sortFunction(a.key.toLowerCase(), b.key.toLowerCase(), val.toLowerCase());
+          };
+          matchingData.sort(sortFunctionBound);
+        }
+
+        // Render
+        for (var i = 0; i < matchingData.length; i++) {
+          var _entry = matchingData[i];
+          var $autocompleteOption = $('<li></li>');
+          if (!!_entry.data) {
+            $autocompleteOption.append("<img src=\"" + _entry.data + "\" class=\"right circle\"><span>" + _entry.key + "</span>");
+          } else {
+            $autocompleteOption.append('<span>' + _entry.key + '</span>');
+          }
+
+          $(this.container).append($autocompleteOption);
+          this._highlight(val, $autocompleteOption);
+        }
+      }
+
+      /**
+       * Open Autocomplete Dropdown
+       */
+
+    }, {
+      key: "open",
+      value: function open() {
+        var val = this.el.value.toLowerCase();
+
+        this._resetAutocomplete();
+
+        if (val.length >= this.options.minLength) {
+          this.isOpen = true;
+          this._renderDropdown(this.options.data, val);
+        }
+
+        // Open dropdown
+        if (!this.dropdown.isOpen) {
+          this.dropdown.open();
+        } else {
+          // Recalculate dropdown when its already open
+          this.dropdown.recalculateDimensions();
+        }
+      }
+
+      /**
+       * Close Autocomplete Dropdown
+       */
+
+    }, {
+      key: "close",
+      value: function close() {
+        this.dropdown.close();
+      }
+
+      /**
+       * Update Data
+       * @param {Object} data
+       */
+
+    }, {
+      key: "updateData",
+      value: function updateData(data) {
+        var val = this.el.value.toLowerCase();
+        this.options.data = data;
+
+        if (this.isOpen) {
+          this._renderDropdown(data, val);
+        }
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(Autocomplete.__proto__ || Object.getPrototypeOf(Autocomplete), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Autocomplete;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Autocomplete;
+  }(Component);
+
+  /**
+   * @static
+   * @memberof Autocomplete
+   */
+
+
+  Autocomplete._keydown = false;
+
+  M.Autocomplete = Autocomplete;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(Autocomplete, 'autocomplete', 'M_Autocomplete');
+  }
+})(cash);
+;(function ($) {
+  // Function to update labels of text fields
+  M.updateTextFields = function () {
+    var input_selector = 'input[type=text], input[type=password], input[type=email], input[type=url], input[type=tel], input[type=number], input[type=search], input[type=date], input[type=time], textarea';
+    $(input_selector).each(function (element, index) {
+      var $this = $(this);
+      if (element.value.length > 0 || $(element).is(':focus') || element.autofocus || $this.attr('placeholder') !== null) {
+        $this.siblings('label').addClass('active');
+      } else if (element.validity) {
+        $this.siblings('label').toggleClass('active', element.validity.badInput === true);
+      } else {
+        $this.siblings('label').removeClass('active');
+      }
+    });
+  };
+
+  M.validate_field = function (object) {
+    var hasLength = object.attr('data-length') !== null;
+    var lenAttr = parseInt(object.attr('data-length'));
+    var len = object[0].value.length;
+
+    if (len === 0 && object[0].validity.badInput === false && !object.is(':required')) {
+      if (object.hasClass('validate')) {
+        object.removeClass('valid');
+        object.removeClass('invalid');
+      }
+    } else {
+      if (object.hasClass('validate')) {
+        // Check for character counter attributes
+        if (object.is(':valid') && hasLength && len <= lenAttr || object.is(':valid') && !hasLength) {
+          object.removeClass('invalid');
+          object.addClass('valid');
+        } else {
+          object.removeClass('valid');
+          object.addClass('invalid');
+        }
+      }
+    }
+  };
+
+  M.textareaAutoResize = function ($textarea) {
+    // Wrap if native element
+    if ($textarea instanceof Element) {
+      $textarea = $($textarea);
+    }
+
+    if (!$textarea.length) {
+      console.error('No textarea element found');
+      return;
+    }
+
+    // Textarea Auto Resize
+    var hiddenDiv = $('.hiddendiv').first();
+    if (!hiddenDiv.length) {
+      hiddenDiv = $('<div class="hiddendiv common"></div>');
+      $('body').append(hiddenDiv);
+    }
+
+    // Set font properties of hiddenDiv
+    var fontFamily = $textarea.css('font-family');
+    var fontSize = $textarea.css('font-size');
+    var lineHeight = $textarea.css('line-height');
+
+    // Firefox can't handle padding shorthand.
+    var paddingTop = $textarea.css('padding-top');
+    var paddingRight = $textarea.css('padding-right');
+    var paddingBottom = $textarea.css('padding-bottom');
+    var paddingLeft = $textarea.css('padding-left');
+
+    if (fontSize) {
+      hiddenDiv.css('font-size', fontSize);
+    }
+    if (fontFamily) {
+      hiddenDiv.css('font-family', fontFamily);
+    }
+    if (lineHeight) {
+      hiddenDiv.css('line-height', lineHeight);
+    }
+    if (paddingTop) {
+      hiddenDiv.css('padding-top', paddingTop);
+    }
+    if (paddingRight) {
+      hiddenDiv.css('padding-right', paddingRight);
+    }
+    if (paddingBottom) {
+      hiddenDiv.css('padding-bottom', paddingBottom);
+    }
+    if (paddingLeft) {
+      hiddenDiv.css('padding-left', paddingLeft);
+    }
+
+    // Set original-height, if none
+    if (!$textarea.data('original-height')) {
+      $textarea.data('original-height', $textarea.height());
+    }
+
+    if ($textarea.attr('wrap') === 'off') {
+      hiddenDiv.css('overflow-wrap', 'normal').css('white-space', 'pre');
+    }
+
+    hiddenDiv.text($textarea[0].value + '\n');
+    var content = hiddenDiv.html().replace(/\n/g, '<br>');
+    hiddenDiv.html(content);
+
+    // When textarea is hidden, width goes crazy.
+    // Approximate with half of window size
+
+    if ($textarea[0].offsetWidth > 0 && $textarea[0].offsetHeight > 0) {
+      hiddenDiv.css('width', $textarea.width() + 'px');
+    } else {
+      hiddenDiv.css('width', window.innerWidth / 2 + 'px');
+    }
+
+    /**
+     * Resize if the new height is greater than the
+     * original height of the textarea
+     */
+    if ($textarea.data('original-height') <= hiddenDiv.innerHeight()) {
+      $textarea.css('height', hiddenDiv.innerHeight() + 'px');
+    } else if ($textarea[0].value.length < $textarea.data('previous-length')) {
+      /**
+       * In case the new height is less than original height, it
+       * means the textarea has less text than before
+       * So we set the height to the original one
+       */
+      $textarea.css('height', $textarea.data('original-height') + 'px');
+    }
+    $textarea.data('previous-length', $textarea[0].value.length);
+  };
+
+  $(document).ready(function () {
+    // Text based inputs
+    var input_selector = 'input[type=text], input[type=password], input[type=email], input[type=url], input[type=tel], input[type=number], input[type=search], input[type=date], input[type=time], textarea';
+
+    // Add active if form auto complete
+    $(document).on('change', input_selector, function () {
+      if (this.value.length !== 0 || $(this).attr('placeholder') !== null) {
+        $(this).siblings('label').addClass('active');
+      }
+      M.validate_field($(this));
+    });
+
+    // Add active if input element has been pre-populated on document ready
+    $(document).ready(function () {
+      M.updateTextFields();
+    });
+
+    // HTML DOM FORM RESET handling
+    $(document).on('reset', function (e) {
+      var formReset = $(e.target);
+      if (formReset.is('form')) {
+        formReset.find(input_selector).removeClass('valid').removeClass('invalid');
+        formReset.find(input_selector).each(function (e) {
+          if (this.value.length) {
+            $(this).siblings('label').removeClass('active');
+          }
+        });
+
+        // Reset select (after native reset)
+        setTimeout(function () {
+          formReset.find('select').each(function () {
+            // check if initialized
+            if (this.M_FormSelect) {
+              $(this).trigger('change');
+            }
+          });
+        }, 0);
+      }
+    });
+
+    /**
+     * Add active when element has focus
+     * @param {Event} e
+     */
+    document.addEventListener('focus', function (e) {
+      if ($(e.target).is(input_selector)) {
+        $(e.target).siblings('label, .prefix').addClass('active');
+      }
+    }, true);
+
+    /**
+     * Remove active when element is blurred
+     * @param {Event} e
+     */
+    document.addEventListener('blur', function (e) {
+      var $inputElement = $(e.target);
+      if ($inputElement.is(input_selector)) {
+        var selector = '.prefix';
+
+        if ($inputElement[0].value.length === 0 && $inputElement[0].validity.badInput !== true && $inputElement.attr('placeholder') === null) {
+          selector += ', label';
+        }
+        $inputElement.siblings(selector).removeClass('active');
+        M.validate_field($inputElement);
+      }
+    }, true);
+
+    // Radio and Checkbox focus class
+    var radio_checkbox = 'input[type=radio], input[type=checkbox]';
+    $(document).on('keyup', radio_checkbox, function (e) {
+      // TAB, check if tabbing to radio or checkbox.
+      if (e.which === M.keys.TAB) {
+        $(this).addClass('tabbed');
+        var $this = $(this);
+        $this.one('blur', function (e) {
+          $(this).removeClass('tabbed');
+        });
+        return;
+      }
+    });
+
+    var text_area_selector = '.materialize-textarea';
+    $(text_area_selector).each(function () {
+      var $textarea = $(this);
+      /**
+       * Resize textarea on document load after storing
+       * the original height and the original length
+       */
+      $textarea.data('original-height', $textarea.height());
+      $textarea.data('previous-length', this.value.length);
+      M.textareaAutoResize($textarea);
+    });
+
+    $(document).on('keyup', text_area_selector, function () {
+      M.textareaAutoResize($(this));
+    });
+    $(document).on('keydown', text_area_selector, function () {
+      M.textareaAutoResize($(this));
+    });
+
+    // File Input Path
+    $(document).on('change', '.file-field input[type="file"]', function () {
+      var file_field = $(this).closest('.file-field');
+      var path_input = file_field.find('input.file-path');
+      var files = $(this)[0].files;
+      var file_names = [];
+      for (var i = 0; i < files.length; i++) {
+        file_names.push(files[i].name);
+      }
+      path_input[0].value = file_names.join(', ');
+      path_input.trigger('change');
+    });
+  }); // End of $(document).ready
+})(cash);
+;(function ($, anim) {
+  'use strict';
+
+  var _defaults = {
+    indicators: true,
+    height: 400,
+    duration: 500,
+    interval: 6000
+  };
+
+  /**
+   * @class
+   *
+   */
+
+  var Slider = function (_Component11) {
+    _inherits(Slider, _Component11);
+
+    /**
+     * Construct Slider instance and set up overlay
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function Slider(el, options) {
+      _classCallCheck(this, Slider);
+
+      var _this40 = _possibleConstructorReturn(this, (Slider.__proto__ || Object.getPrototypeOf(Slider)).call(this, Slider, el, options));
+
+      _this40.el.M_Slider = _this40;
+
+      /**
+       * Options for the modal
+       * @member Slider#options
+       * @prop {Boolean} [indicators=true] - Show indicators
+       * @prop {Number} [height=400] - height of slider
+       * @prop {Number} [duration=500] - Length in ms of slide transition
+       * @prop {Number} [interval=6000] - Length in ms of slide interval
+       */
+      _this40.options = $.extend({}, Slider.defaults, options);
+
+      // setup
+      _this40.$slider = _this40.$el.find('.slides');
+      _this40.$slides = _this40.$slider.children('li');
+      _this40.activeIndex = _this40.$slides.filter(function (item) {
+        return $(item).hasClass('active');
+      }).first().index();
+      if (_this40.activeIndex != -1) {
+        _this40.$active = _this40.$slides.eq(_this40.activeIndex);
+      }
+
+      _this40._setSliderHeight();
+
+      // Set initial positions of captions
+      _this40.$slides.find('.caption').each(function (el) {
+        _this40._animateCaptionIn(el, 0);
+      });
+
+      // Move img src into background-image
+      _this40.$slides.find('img').each(function (el) {
+        var placeholderBase64 = '';
+        if ($(el).attr('src') !== placeholderBase64) {
+          $(el).css('background-image', 'url("' + $(el).attr('src') + '")');
+          $(el).attr('src', placeholderBase64);
+        }
+      });
+
+      _this40._setupIndicators();
+
+      // Show active slide
+      if (_this40.$active) {
+        _this40.$active.css('display', 'block');
+      } else {
+        _this40.$slides.first().addClass('active');
+        anim({
+          targets: _this40.$slides.first()[0],
+          opacity: 1,
+          duration: _this40.options.duration,
+          easing: 'easeOutQuad'
+        });
+
+        _this40.activeIndex = 0;
+        _this40.$active = _this40.$slides.eq(_this40.activeIndex);
+
+        // Update indicators
+        if (_this40.options.indicators) {
+          _this40.$indicators.eq(_this40.activeIndex).addClass('active');
+        }
+      }
+
+      // Adjust height to current slide
+      _this40.$active.find('img').each(function (el) {
+        anim({
+          targets: _this40.$active.find('.caption')[0],
+          opacity: 1,
+          translateX: 0,
+          translateY: 0,
+          duration: _this40.options.duration,
+          easing: 'easeOutQuad'
+        });
+      });
+
+      _this40._setupEventHandlers();
+
+      // auto scroll
+      _this40.start();
+      return _this40;
+    }
+
+    _createClass(Slider, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        this.pause();
+        this._removeIndicators();
+        this._removeEventHandlers();
+        this.el.M_Slider = undefined;
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        var _this41 = this;
+
+        this._handleIntervalBound = this._handleInterval.bind(this);
+        this._handleIndicatorClickBound = this._handleIndicatorClick.bind(this);
+
+        if (this.options.indicators) {
+          this.$indicators.each(function (el) {
+            el.addEventListener('click', _this41._handleIndicatorClickBound);
+          });
+        }
+      }
+
+      /**
+       * Remove Event Handlers
+       */
+
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        var _this42 = this;
+
+        if (this.options.indicators) {
+          this.$indicators.each(function (el) {
+            el.removeEventListener('click', _this42._handleIndicatorClickBound);
+          });
+        }
+      }
+
+      /**
+       * Handle indicator click
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleIndicatorClick",
+      value: function _handleIndicatorClick(e) {
+        var currIndex = $(e.target).index();
+        this.set(currIndex);
+      }
+
+      /**
+       * Handle Interval
+       */
+
+    }, {
+      key: "_handleInterval",
+      value: function _handleInterval() {
+        var newActiveIndex = this.$slider.find('.active').index();
+        if (this.$slides.length === newActiveIndex + 1) newActiveIndex = 0;
+        // loop to start
+        else newActiveIndex += 1;
+
+        this.set(newActiveIndex);
+      }
+
+      /**
+       * Animate in caption
+       * @param {Element} caption
+       * @param {Number} duration
+       */
+
+    }, {
+      key: "_animateCaptionIn",
+      value: function _animateCaptionIn(caption, duration) {
+        var animOptions = {
+          targets: caption,
+          opacity: 0,
+          duration: duration,
+          easing: 'easeOutQuad'
+        };
+
+        if ($(caption).hasClass('center-align')) {
+          animOptions.translateY = -100;
+        } else if ($(caption).hasClass('right-align')) {
+          animOptions.translateX = 100;
+        } else if ($(caption).hasClass('left-align')) {
+          animOptions.translateX = -100;
+        }
+
+        anim(animOptions);
+      }
+
+      /**
+       * Set height of slider
+       */
+
+    }, {
+      key: "_setSliderHeight",
+      value: function _setSliderHeight() {
+        // If fullscreen, do nothing
+        if (!this.$el.hasClass('fullscreen')) {
+          if (this.options.indicators) {
+            // Add height if indicators are present
+            this.$el.css('height', this.options.height + 40 + 'px');
+          } else {
+            this.$el.css('height', this.options.height + 'px');
+          }
+          this.$slider.css('height', this.options.height + 'px');
+        }
+      }
+
+      /**
+       * Setup indicators
+       */
+
+    }, {
+      key: "_setupIndicators",
+      value: function _setupIndicators() {
+        var _this43 = this;
+
+        if (this.options.indicators) {
+          this.$indicators = $('<ul class="indicators"></ul>');
+          this.$slides.each(function (el, index) {
+            var $indicator = $('<li class="indicator-item"></li>');
+            _this43.$indicators.append($indicator[0]);
+          });
+          this.$el.append(this.$indicators[0]);
+          this.$indicators = this.$indicators.children('li.indicator-item');
+        }
+      }
+
+      /**
+       * Remove indicators
+       */
+
+    }, {
+      key: "_removeIndicators",
+      value: function _removeIndicators() {
+        this.$el.find('ul.indicators').remove();
+      }
+
+      /**
+       * Cycle to nth item
+       * @param {Number} index
+       */
+
+    }, {
+      key: "set",
+      value: function set(index) {
+        var _this44 = this;
+
+        // Wrap around indices.
+        if (index >= this.$slides.length) index = 0;else if (index < 0) index = this.$slides.length - 1;
+
+        // Only do if index changes
+        if (this.activeIndex != index) {
+          this.$active = this.$slides.eq(this.activeIndex);
+          var $caption = this.$active.find('.caption');
+          this.$active.removeClass('active');
+
+          anim({
+            targets: this.$active[0],
+            opacity: 0,
+            duration: this.options.duration,
+            easing: 'easeOutQuad',
+            complete: function () {
+              _this44.$slides.not('.active').each(function (el) {
+                anim({
+                  targets: el,
+                  opacity: 0,
+                  translateX: 0,
+                  translateY: 0,
+                  duration: 0,
+                  easing: 'easeOutQuad'
+                });
+              });
+            }
+          });
+
+          this._animateCaptionIn($caption[0], this.options.duration);
+
+          // Update indicators
+          if (this.options.indicators) {
+            this.$indicators.eq(this.activeIndex).removeClass('active');
+            this.$indicators.eq(index).addClass('active');
+          }
+
+          anim({
+            targets: this.$slides.eq(index)[0],
+            opacity: 1,
+            duration: this.options.duration,
+            easing: 'easeOutQuad'
+          });
+
+          anim({
+            targets: this.$slides.eq(index).find('.caption')[0],
+            opacity: 1,
+            translateX: 0,
+            translateY: 0,
+            duration: this.options.duration,
+            delay: this.options.duration,
+            easing: 'easeOutQuad'
+          });
+
+          this.$slides.eq(index).addClass('active');
+          this.activeIndex = index;
+
+          // Reset interval
+          this.start();
+        }
+      }
+
+      /**
+       * Pause slider interval
+       */
+
+    }, {
+      key: "pause",
+      value: function pause() {
+        clearInterval(this.interval);
+      }
+
+      /**
+       * Start slider interval
+       */
+
+    }, {
+      key: "start",
+      value: function start() {
+        clearInterval(this.interval);
+        this.interval = setInterval(this._handleIntervalBound, this.options.duration + this.options.interval);
+      }
+
+      /**
+       * Move to next slide
+       */
+
+    }, {
+      key: "next",
+      value: function next() {
+        var newIndex = this.activeIndex + 1;
+
+        // Wrap around indices.
+        if (newIndex >= this.$slides.length) newIndex = 0;else if (newIndex < 0) newIndex = this.$slides.length - 1;
+
+        this.set(newIndex);
+      }
+
+      /**
+       * Move to previous slide
+       */
+
+    }, {
+      key: "prev",
+      value: function prev() {
+        var newIndex = this.activeIndex - 1;
+
+        // Wrap around indices.
+        if (newIndex >= this.$slides.length) newIndex = 0;else if (newIndex < 0) newIndex = this.$slides.length - 1;
+
+        this.set(newIndex);
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(Slider.__proto__ || Object.getPrototypeOf(Slider), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Slider;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Slider;
+  }(Component);
+
+  M.Slider = Slider;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(Slider, 'slider', 'M_Slider');
+  }
+})(cash, M.anime);
+;(function ($, anim) {
+  $(document).on('click', '.card', function (e) {
+    if ($(this).children('.card-reveal').length) {
+      var $card = $(e.target).closest('.card');
+      if ($card.data('initialOverflow') === undefined) {
+        $card.data('initialOverflow', $card.css('overflow') === undefined ? '' : $card.css('overflow'));
+      }
+      var $cardReveal = $(this).find('.card-reveal');
+      if ($(e.target).is($('.card-reveal .card-title')) || $(e.target).is($('.card-reveal .card-title i'))) {
+        // Make Reveal animate down and display none
+        anim({
+          targets: $cardReveal[0],
+          translateY: 0,
+          duration: 225,
+          easing: 'easeInOutQuad',
+          complete: function (anim) {
+            var el = anim.animatables[0].target;
+            $(el).css({ display: 'none' });
+            $card.css('overflow', $card.data('initialOverflow'));
+          }
+        });
+      } else if ($(e.target).is($('.card .activator')) || $(e.target).is($('.card .activator i'))) {
+        $card.css('overflow', 'hidden');
+        $cardReveal.css({ display: 'block' });
+        anim({
+          targets: $cardReveal[0],
+          translateY: '-100%',
+          duration: 300,
+          easing: 'easeInOutQuad'
+        });
+      }
+    }
+  });
+})(cash, M.anime);
+;(function ($) {
+  'use strict';
+
+  var _defaults = {
+    data: [],
+    placeholder: '',
+    secondaryPlaceholder: '',
+    autocompleteOptions: {},
+    limit: Infinity,
+    onChipAdd: null,
+    onChipSelect: null,
+    onChipDelete: null
+  };
+
+  /**
+   * @typedef {Object} chip
+   * @property {String} tag  chip tag string
+   * @property {String} [image]  chip avatar image string
+   */
+
+  /**
+   * @class
+   *
+   */
+
+  var Chips = function (_Component12) {
+    _inherits(Chips, _Component12);
+
+    /**
+     * Construct Chips instance and set up overlay
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function Chips(el, options) {
+      _classCallCheck(this, Chips);
+
+      var _this45 = _possibleConstructorReturn(this, (Chips.__proto__ || Object.getPrototypeOf(Chips)).call(this, Chips, el, options));
+
+      _this45.el.M_Chips = _this45;
+
+      /**
+       * Options for the modal
+       * @member Chips#options
+       * @prop {Array} data
+       * @prop {String} placeholder
+       * @prop {String} secondaryPlaceholder
+       * @prop {Object} autocompleteOptions
+       */
+      _this45.options = $.extend({}, Chips.defaults, options);
+
+      _this45.$el.addClass('chips input-field');
+      _this45.chipsData = [];
+      _this45.$chips = $();
+      _this45._setupInput();
+      _this45.hasAutocomplete = Object.keys(_this45.options.autocompleteOptions).length > 0;
+
+      // Set input id
+      if (!_this45.$input.attr('id')) {
+        _this45.$input.attr('id', M.guid());
+      }
+
+      // Render initial chips
+      if (_this45.options.data.length) {
+        _this45.chipsData = _this45.options.data;
+        _this45._renderChips(_this45.chipsData);
+      }
+
+      // Setup autocomplete if needed
+      if (_this45.hasAutocomplete) {
+        _this45._setupAutocomplete();
+      }
+
+      _this45._setPlaceholder();
+      _this45._setupLabel();
+      _this45._setupEventHandlers();
+      return _this45;
+    }
+
+    _createClass(Chips, [{
+      key: "getData",
+
+
+      /**
+       * Get Chips Data
+       */
+      value: function getData() {
+        return this.chipsData;
+      }
+
+      /**
+       * Teardown component
+       */
+
+    }, {
+      key: "destroy",
+      value: function destroy() {
+        this._removeEventHandlers();
+        this.$chips.remove();
+        this.el.M_Chips = undefined;
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        this._handleChipClickBound = this._handleChipClick.bind(this);
+        this._handleInputKeydownBound = this._handleInputKeydown.bind(this);
+        this._handleInputFocusBound = this._handleInputFocus.bind(this);
+        this._handleInputBlurBound = this._handleInputBlur.bind(this);
+
+        this.el.addEventListener('click', this._handleChipClickBound);
+        document.addEventListener('keydown', Chips._handleChipsKeydown);
+        document.addEventListener('keyup', Chips._handleChipsKeyup);
+        this.el.addEventListener('blur', Chips._handleChipsBlur, true);
+        this.$input[0].addEventListener('focus', this._handleInputFocusBound);
+        this.$input[0].addEventListener('blur', this._handleInputBlurBound);
+        this.$input[0].addEventListener('keydown', this._handleInputKeydownBound);
+      }
+
+      /**
+       * Remove Event Handlers
+       */
+
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        this.el.removeEventListener('click', this._handleChipClickBound);
+        document.removeEventListener('keydown', Chips._handleChipsKeydown);
+        document.removeEventListener('keyup', Chips._handleChipsKeyup);
+        this.el.removeEventListener('blur', Chips._handleChipsBlur, true);
+        this.$input[0].removeEventListener('focus', this._handleInputFocusBound);
+        this.$input[0].removeEventListener('blur', this._handleInputBlurBound);
+        this.$input[0].removeEventListener('keydown', this._handleInputKeydownBound);
+      }
+
+      /**
+       * Handle Chip Click
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleChipClick",
+      value: function _handleChipClick(e) {
+        var $chip = $(e.target).closest('.chip');
+        var clickedClose = $(e.target).is('.close');
+        if ($chip.length) {
+          var index = $chip.index();
+          if (clickedClose) {
+            // delete chip
+            this.deleteChip(index);
+            this.$input[0].focus();
+          } else {
+            // select chip
+            this.selectChip(index);
+          }
+
+          // Default handle click to focus on input
+        } else {
+          this.$input[0].focus();
+        }
+      }
+
+      /**
+       * Handle Chips Keydown
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleInputFocus",
+
+
+      /**
+       * Handle Input Focus
+       */
+      value: function _handleInputFocus() {
+        this.$el.addClass('focus');
+      }
+
+      /**
+       * Handle Input Blur
+       */
+
+    }, {
+      key: "_handleInputBlur",
+      value: function _handleInputBlur() {
+        this.$el.removeClass('focus');
+      }
+
+      /**
+       * Handle Input Keydown
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleInputKeydown",
+      value: function _handleInputKeydown(e) {
+        Chips._keydown = true;
+
+        // enter
+        if (e.keyCode === 13) {
+          // Override enter if autocompleting.
+          if (this.hasAutocomplete && this.autocomplete && this.autocomplete.isOpen) {
+            return;
+          }
+
+          e.preventDefault();
+          this.addChip({
+            tag: this.$input[0].value
+          });
+          this.$input[0].value = '';
+
+          // delete or left
+        } else if ((e.keyCode === 8 || e.keyCode === 37) && this.$input[0].value === '' && this.chipsData.length) {
+          e.preventDefault();
+          this.selectChip(this.chipsData.length - 1);
+        }
+      }
+
+      /**
+       * Render Chip
+       * @param {chip} chip
+       * @return {Element}
+       */
+
+    }, {
+      key: "_renderChip",
+      value: function _renderChip(chip) {
+        if (!chip.tag) {
+          return;
+        }
+
+        var renderedChip = document.createElement('div');
+        var closeIcon = document.createElement('i');
+        renderedChip.classList.add('chip');
+        renderedChip.textContent = chip.tag;
+        renderedChip.setAttribute('tabindex', 0);
+        $(closeIcon).addClass('material-icons close');
+        closeIcon.textContent = 'close';
+
+        // attach image if needed
+        if (chip.image) {
+          var img = document.createElement('img');
+          img.setAttribute('src', chip.image);
+          renderedChip.insertBefore(img, renderedChip.firstChild);
+        }
+
+        renderedChip.appendChild(closeIcon);
+        return renderedChip;
+      }
+
+      /**
+       * Render Chips
+       */
+
+    }, {
+      key: "_renderChips",
+      value: function _renderChips() {
+        this.$chips.remove();
+        for (var i = 0; i < this.chipsData.length; i++) {
+          var chipEl = this._renderChip(this.chipsData[i]);
+          this.$el.append(chipEl);
+          this.$chips.add(chipEl);
+        }
+
+        // move input to end
+        this.$el.append(this.$input[0]);
+      }
+
+      /**
+       * Setup Autocomplete
+       */
+
+    }, {
+      key: "_setupAutocomplete",
+      value: function _setupAutocomplete() {
+        var _this46 = this;
+
+        this.options.autocompleteOptions.onAutocomplete = function (val) {
+          _this46.addChip({
+            tag: val
+          });
+          _this46.$input[0].value = '';
+          _this46.$input[0].focus();
+        };
+
+        this.autocomplete = M.Autocomplete.init(this.$input[0], this.options.autocompleteOptions);
+      }
+
+      /**
+       * Setup Input
+       */
+
+    }, {
+      key: "_setupInput",
+      value: function _setupInput() {
+        this.$input = this.$el.find('input');
+        if (!this.$input.length) {
+          this.$input = $('<input></input>');
+          this.$el.append(this.$input);
+        }
+
+        this.$input.addClass('input');
+      }
+
+      /**
+       * Setup Label
+       */
+
+    }, {
+      key: "_setupLabel",
+      value: function _setupLabel() {
+        this.$label = this.$el.find('label');
+        if (this.$label.length) {
+          this.$label.setAttribute('for', this.$input.attr('id'));
+        }
+      }
+
+      /**
+       * Set placeholder
+       */
+
+    }, {
+      key: "_setPlaceholder",
+      value: function _setPlaceholder() {
+        if (this.chipsData !== undefined && !this.chipsData.length && this.options.placeholder) {
+          $(this.$input).prop('placeholder', this.options.placeholder);
+        } else if ((this.chipsData === undefined || !!this.chipsData.length) && this.options.secondaryPlaceholder) {
+          $(this.$input).prop('placeholder', this.options.secondaryPlaceholder);
+        }
+      }
+
+      /**
+       * Check if chip is valid
+       * @param {chip} chip
+       */
+
+    }, {
+      key: "_isValid",
+      value: function _isValid(chip) {
+        if (chip.hasOwnProperty('tag') && chip.tag !== '') {
+          var exists = false;
+          for (var i = 0; i < this.chipsData.length; i++) {
+            if (this.chipsData[i].tag === chip.tag) {
+              exists = true;
+              break;
+            }
+          }
+          return !exists;
+        }
+
+        return false;
+      }
+
+      /**
+       * Add chip
+       * @param {chip} chip
+       */
+
+    }, {
+      key: "addChip",
+      value: function addChip(chip) {
+        if (!this._isValid(chip) || this.chipsData.length >= this.options.limit) {
+          return;
+        }
+
+        var renderedChip = this._renderChip(chip);
+        this.$chips.add(renderedChip);
+        this.chipsData.push(chip);
+        $(this.$input).before(renderedChip);
+        this._setPlaceholder();
+
+        // fire chipAdd callback
+        if (typeof this.options.onChipAdd === 'function') {
+          this.options.onChipAdd.call(this, this.$el, renderedChip);
+        }
+      }
+
+      /**
+       * Delete chip
+       * @param {Number} chip
+       */
+
+    }, {
+      key: "deleteChip",
+      value: function deleteChip(chipIndex) {
+        var $chip = this.$chips.eq(chipIndex);
+        this.$chips.eq(chipIndex).remove();
+        this.$chips = this.$chips.filter(function (el) {
+          return $(el).index() >= 0;
+        });
+        this.chipsData.splice(chipIndex, 1);
+        this._setPlaceholder();
+
+        // fire chipDelete callback
+        if (typeof this.options.onChipDelete === 'function') {
+          this.options.onChipDelete.call(this, this.$el, $chip[0]);
+        }
+      }
+
+      /**
+       * Select chip
+       * @param {Number} chip
+       */
+
+    }, {
+      key: "selectChip",
+      value: function selectChip(chipIndex) {
+        var $chip = this.$chips.eq(chipIndex);
+        this._selectedChip = $chip;
+        $chip[0].focus();
+
+        // fire chipSelect callback
+        if (typeof this.options.onChipSelect === 'function') {
+          this.options.onChipSelect.call(this, this.$el, $chip[0]);
+        }
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(Chips.__proto__ || Object.getPrototypeOf(Chips), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Chips;
+      }
+    }, {
+      key: "_handleChipsKeydown",
+      value: function _handleChipsKeydown(e) {
+        Chips._keydown = true;
+
+        var $chips = $(e.target).closest('.chips');
+        var chipsKeydown = e.target && $chips.length;
+
+        // Don't handle keydown inputs on input and textarea
+        if ($(e.target).is('input, textarea') || !chipsKeydown) {
+          return;
+        }
+
+        var currChips = $chips[0].M_Chips;
+
+        // backspace and delete
+        if (e.keyCode === 8 || e.keyCode === 46) {
+          e.preventDefault();
+
+          var selectIndex = currChips.chipsData.length;
+          if (currChips._selectedChip) {
+            var index = currChips._selectedChip.index();
+            currChips.deleteChip(index);
+            currChips._selectedChip = null;
+
+            // Make sure selectIndex doesn't go negative
+            selectIndex = Math.max(index - 1, 0);
+          }
+
+          if (currChips.chipsData.length) {
+            currChips.selectChip(selectIndex);
+          }
+
+          // left arrow key
+        } else if (e.keyCode === 37) {
+          if (currChips._selectedChip) {
+            var _selectIndex = currChips._selectedChip.index() - 1;
+            if (_selectIndex < 0) {
+              return;
+            }
+            currChips.selectChip(_selectIndex);
+          }
+
+          // right arrow key
+        } else if (e.keyCode === 39) {
+          if (currChips._selectedChip) {
+            var _selectIndex2 = currChips._selectedChip.index() + 1;
+
+            if (_selectIndex2 >= currChips.chipsData.length) {
+              currChips.$input[0].focus();
+            } else {
+              currChips.selectChip(_selectIndex2);
+            }
+          }
+        }
+      }
+
+      /**
+       * Handle Chips Keyup
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleChipsKeyup",
+      value: function _handleChipsKeyup(e) {
+        Chips._keydown = false;
+      }
+
+      /**
+       * Handle Chips Blur
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleChipsBlur",
+      value: function _handleChipsBlur(e) {
+        if (!Chips._keydown) {
+          var $chips = $(e.target).closest('.chips');
+          var currChips = $chips[0].M_Chips;
+
+          currChips._selectedChip = null;
+        }
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Chips;
+  }(Component);
+
+  /**
+   * @static
+   * @memberof Chips
+   */
+
+
+  Chips._keydown = false;
+
+  M.Chips = Chips;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(Chips, 'chips', 'M_Chips');
+  }
+
+  $(document).ready(function () {
+    // Handle removal of static chips.
+    $(document.body).on('click', '.chip .close', function () {
+      var $chips = $(this).closest('.chips');
+      if ($chips.length && $chips[0].M_Chips) {
+        return;
+      }
+      $(this).closest('.chip').remove();
+    });
+  });
+})(cash);
+;(function ($) {
+  'use strict';
+
+  var _defaults = {
+    top: 0,
+    bottom: Infinity,
+    offset: 0,
+    onPositionChange: null
+  };
+
+  /**
+   * @class
+   *
+   */
+
+  var Pushpin = function (_Component13) {
+    _inherits(Pushpin, _Component13);
+
+    /**
+     * Construct Pushpin instance
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function Pushpin(el, options) {
+      _classCallCheck(this, Pushpin);
+
+      var _this47 = _possibleConstructorReturn(this, (Pushpin.__proto__ || Object.getPrototypeOf(Pushpin)).call(this, Pushpin, el, options));
+
+      _this47.el.M_Pushpin = _this47;
+
+      /**
+       * Options for the modal
+       * @member Pushpin#options
+       */
+      _this47.options = $.extend({}, Pushpin.defaults, options);
+
+      _this47.originalOffset = _this47.el.offsetTop;
+      Pushpin._pushpins.push(_this47);
+      _this47._setupEventHandlers();
+      _this47._updatePosition();
+      return _this47;
+    }
+
+    _createClass(Pushpin, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        this.el.style.top = null;
+        this._removePinClasses();
+        this._removeEventHandlers();
+
+        // Remove pushpin Inst
+        var index = Pushpin._pushpins.indexOf(this);
+        Pushpin._pushpins.splice(index, 1);
+      }
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        document.addEventListener('scroll', Pushpin._updateElements);
+      }
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        document.removeEventListener('scroll', Pushpin._updateElements);
+      }
+    }, {
+      key: "_updatePosition",
+      value: function _updatePosition() {
+        var scrolled = M.getDocumentScrollTop() + this.options.offset;
+
+        if (this.options.top <= scrolled && this.options.bottom >= scrolled && !this.el.classList.contains('pinned')) {
+          this._removePinClasses();
+          this.el.style.top = this.options.offset + "px";
+          this.el.classList.add('pinned');
+
+          // onPositionChange callback
+          if (typeof this.options.onPositionChange === 'function') {
+            this.options.onPositionChange.call(this, 'pinned');
+          }
+        }
+
+        // Add pin-top (when scrolled position is above top)
+        if (scrolled < this.options.top && !this.el.classList.contains('pin-top')) {
+          this._removePinClasses();
+          this.el.style.top = 0;
+          this.el.classList.add('pin-top');
+
+          // onPositionChange callback
+          if (typeof this.options.onPositionChange === 'function') {
+            this.options.onPositionChange.call(this, 'pin-top');
+          }
+        }
+
+        // Add pin-bottom (when scrolled position is below bottom)
+        if (scrolled > this.options.bottom && !this.el.classList.contains('pin-bottom')) {
+          this._removePinClasses();
+          this.el.classList.add('pin-bottom');
+          this.el.style.top = this.options.bottom - this.originalOffset + "px";
+
+          // onPositionChange callback
+          if (typeof this.options.onPositionChange === 'function') {
+            this.options.onPositionChange.call(this, 'pin-bottom');
+          }
+        }
+      }
+    }, {
+      key: "_removePinClasses",
+      value: function _removePinClasses() {
+        // IE 11 bug (can't remove multiple classes in one line)
+        this.el.classList.remove('pin-top');
+        this.el.classList.remove('pinned');
+        this.el.classList.remove('pin-bottom');
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(Pushpin.__proto__ || Object.getPrototypeOf(Pushpin), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Pushpin;
+      }
+    }, {
+      key: "_updateElements",
+      value: function _updateElements() {
+        for (var elIndex in Pushpin._pushpins) {
+          var pInstance = Pushpin._pushpins[elIndex];
+          pInstance._updatePosition();
+        }
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Pushpin;
+  }(Component);
+
+  /**
+   * @static
+   * @memberof Pushpin
+   */
+
+
+  Pushpin._pushpins = [];
+
+  M.Pushpin = Pushpin;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(Pushpin, 'pushpin', 'M_Pushpin');
+  }
+})(cash);
+;(function ($, anim) {
+  'use strict';
+
+  var _defaults = {
+    direction: 'top',
+    hoverEnabled: true,
+    toolbarEnabled: false
+  };
+
+  $.fn.reverse = [].reverse;
+
+  /**
+   * @class
+   *
+   */
+
+  var FloatingActionButton = function (_Component14) {
+    _inherits(FloatingActionButton, _Component14);
+
+    /**
+     * Construct FloatingActionButton instance
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function FloatingActionButton(el, options) {
+      _classCallCheck(this, FloatingActionButton);
+
+      var _this48 = _possibleConstructorReturn(this, (FloatingActionButton.__proto__ || Object.getPrototypeOf(FloatingActionButton)).call(this, FloatingActionButton, el, options));
+
+      _this48.el.M_FloatingActionButton = _this48;
+
+      /**
+       * Options for the fab
+       * @member FloatingActionButton#options
+       * @prop {Boolean} [direction] - Direction fab menu opens
+       * @prop {Boolean} [hoverEnabled=true] - Enable hover vs click
+       * @prop {Boolean} [toolbarEnabled=false] - Enable toolbar transition
+       */
+      _this48.options = $.extend({}, FloatingActionButton.defaults, options);
+
+      _this48.isOpen = false;
+      _this48.$anchor = _this48.$el.children('a').first();
+      _this48.$menu = _this48.$el.children('ul').first();
+      _this48.$floatingBtns = _this48.$el.find('ul .btn-floating');
+      _this48.$floatingBtnsReverse = _this48.$el.find('ul .btn-floating').reverse();
+      _this48.offsetY = 0;
+      _this48.offsetX = 0;
+
+      _this48.$el.addClass("direction-" + _this48.options.direction);
+      if (_this48.options.direction === 'top') {
+        _this48.offsetY = 40;
+      } else if (_this48.options.direction === 'right') {
+        _this48.offsetX = -40;
+      } else if (_this48.options.direction === 'bottom') {
+        _this48.offsetY = -40;
+      } else {
+        _this48.offsetX = 40;
+      }
+      _this48._setupEventHandlers();
+      return _this48;
+    }
+
+    _createClass(FloatingActionButton, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        this._removeEventHandlers();
+        this.el.M_FloatingActionButton = undefined;
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        this._handleFABClickBound = this._handleFABClick.bind(this);
+        this._handleOpenBound = this.open.bind(this);
+        this._handleCloseBound = this.close.bind(this);
+
+        if (this.options.hoverEnabled && !this.options.toolbarEnabled) {
+          this.el.addEventListener('mouseenter', this._handleOpenBound);
+          this.el.addEventListener('mouseleave', this._handleCloseBound);
+        } else {
+          this.el.addEventListener('click', this._handleFABClickBound);
+        }
+      }
+
+      /**
+       * Remove Event Handlers
+       */
+
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        if (this.options.hoverEnabled && !this.options.toolbarEnabled) {
+          this.el.removeEventListener('mouseenter', this._handleOpenBound);
+          this.el.removeEventListener('mouseleave', this._handleCloseBound);
+        } else {
+          this.el.removeEventListener('click', this._handleFABClickBound);
+        }
+      }
+
+      /**
+       * Handle FAB Click
+       */
+
+    }, {
+      key: "_handleFABClick",
+      value: function _handleFABClick() {
+        if (this.isOpen) {
+          this.close();
+        } else {
+          this.open();
+        }
+      }
+
+      /**
+       * Handle Document Click
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleDocumentClick",
+      value: function _handleDocumentClick(e) {
+        if (!$(e.target).closest(this.$menu).length) {
+          this.close();
+        }
+      }
+
+      /**
+       * Open FAB
+       */
+
+    }, {
+      key: "open",
+      value: function open() {
+        if (this.isOpen) {
+          return;
+        }
+
+        if (this.options.toolbarEnabled) {
+          this._animateInToolbar();
+        } else {
+          this._animateInFAB();
+        }
+        this.isOpen = true;
+      }
+
+      /**
+       * Close FAB
+       */
+
+    }, {
+      key: "close",
+      value: function close() {
+        if (!this.isOpen) {
+          return;
+        }
+
+        if (this.options.toolbarEnabled) {
+          window.removeEventListener('scroll', this._handleCloseBound, true);
+          document.body.removeEventListener('click', this._handleDocumentClickBound, true);
+          this._animateOutToolbar();
+        } else {
+          this._animateOutFAB();
+        }
+        this.isOpen = false;
+      }
+
+      /**
+       * Classic FAB Menu open
+       */
+
+    }, {
+      key: "_animateInFAB",
+      value: function _animateInFAB() {
+        var _this49 = this;
+
+        this.$el.addClass('active');
+
+        var time = 0;
+        this.$floatingBtnsReverse.each(function (el) {
+          anim({
+            targets: el,
+            opacity: 1,
+            scale: [0.4, 1],
+            translateY: [_this49.offsetY, 0],
+            translateX: [_this49.offsetX, 0],
+            duration: 275,
+            delay: time,
+            easing: 'easeInOutQuad'
+          });
+          time += 40;
+        });
+      }
+
+      /**
+       * Classic FAB Menu close
+       */
+
+    }, {
+      key: "_animateOutFAB",
+      value: function _animateOutFAB() {
+        var _this50 = this;
+
+        this.$floatingBtnsReverse.each(function (el) {
+          anim.remove(el);
+          anim({
+            targets: el,
+            opacity: 0,
+            scale: 0.4,
+            translateY: _this50.offsetY,
+            translateX: _this50.offsetX,
+            duration: 175,
+            easing: 'easeOutQuad',
+            complete: function () {
+              _this50.$el.removeClass('active');
+            }
+          });
+        });
+      }
+
+      /**
+       * Toolbar transition Menu open
+       */
+
+    }, {
+      key: "_animateInToolbar",
+      value: function _animateInToolbar() {
+        var _this51 = this;
+
+        var scaleFactor = void 0;
+        var windowWidth = window.innerWidth;
+        var windowHeight = window.innerHeight;
+        var btnRect = this.el.getBoundingClientRect();
+        var backdrop = $('<div class="fab-backdrop"></div>');
+        var fabColor = this.$anchor.css('background-color');
+        this.$anchor.append(backdrop);
+
+        this.offsetX = btnRect.left - windowWidth / 2 + btnRect.width / 2;
+        this.offsetY = windowHeight - btnRect.bottom;
+        scaleFactor = windowWidth / backdrop[0].clientWidth;
+        this.btnBottom = btnRect.bottom;
+        this.btnLeft = btnRect.left;
+        this.btnWidth = btnRect.width;
+
+        // Set initial state
+        this.$el.addClass('active');
+        this.$el.css({
+          'text-align': 'center',
+          width: '100%',
+          bottom: 0,
+          left: 0,
+          transform: 'translateX(' + this.offsetX + 'px)',
+          transition: 'none'
+        });
+        this.$anchor.css({
+          transform: 'translateY(' + -this.offsetY + 'px)',
+          transition: 'none'
+        });
+        backdrop.css({
+          'background-color': fabColor
+        });
+
+        setTimeout(function () {
+          _this51.$el.css({
+            transform: '',
+            transition: 'transform .2s cubic-bezier(0.550, 0.085, 0.680, 0.530), background-color 0s linear .2s'
+          });
+          _this51.$anchor.css({
+            overflow: 'visible',
+            transform: '',
+            transition: 'transform .2s'
+          });
+
+          setTimeout(function () {
+            _this51.$el.css({
+              overflow: 'hidden',
+              'background-color': fabColor
+            });
+            backdrop.css({
+              transform: 'scale(' + scaleFactor + ')',
+              transition: 'transform .2s cubic-bezier(0.550, 0.055, 0.675, 0.190)'
+            });
+            _this51.$menu.children('li').children('a').css({
+              opacity: 1
+            });
+
+            // Scroll to close.
+            _this51._handleDocumentClickBound = _this51._handleDocumentClick.bind(_this51);
+            window.addEventListener('scroll', _this51._handleCloseBound, true);
+            document.body.addEventListener('click', _this51._handleDocumentClickBound, true);
+          }, 100);
+        }, 0);
+      }
+
+      /**
+       * Toolbar transition Menu close
+       */
+
+    }, {
+      key: "_animateOutToolbar",
+      value: function _animateOutToolbar() {
+        var _this52 = this;
+
+        var windowWidth = window.innerWidth;
+        var windowHeight = window.innerHeight;
+        var backdrop = this.$el.find('.fab-backdrop');
+        var fabColor = this.$anchor.css('background-color');
+
+        this.offsetX = this.btnLeft - windowWidth / 2 + this.btnWidth / 2;
+        this.offsetY = windowHeight - this.btnBottom;
+
+        // Hide backdrop
+        this.$el.removeClass('active');
+        this.$el.css({
+          'background-color': 'transparent',
+          transition: 'none'
+        });
+        this.$anchor.css({
+          transition: 'none'
+        });
+        backdrop.css({
+          transform: 'scale(0)',
+          'background-color': fabColor
+        });
+        this.$menu.children('li').children('a').css({
+          opacity: ''
+        });
+
+        setTimeout(function () {
+          backdrop.remove();
+
+          // Set initial state.
+          _this52.$el.css({
+            'text-align': '',
+            width: '',
+            bottom: '',
+            left: '',
+            overflow: '',
+            'background-color': '',
+            transform: 'translate3d(' + -_this52.offsetX + 'px,0,0)'
+          });
+          _this52.$anchor.css({
+            overflow: '',
+            transform: 'translate3d(0,' + _this52.offsetY + 'px,0)'
+          });
+
+          setTimeout(function () {
+            _this52.$el.css({
+              transform: 'translate3d(0,0,0)',
+              transition: 'transform .2s'
+            });
+            _this52.$anchor.css({
+              transform: 'translate3d(0,0,0)',
+              transition: 'transform .2s cubic-bezier(0.550, 0.055, 0.675, 0.190)'
+            });
+          }, 20);
+        }, 200);
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(FloatingActionButton.__proto__ || Object.getPrototypeOf(FloatingActionButton), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_FloatingActionButton;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return FloatingActionButton;
+  }(Component);
+
+  M.FloatingActionButton = FloatingActionButton;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(FloatingActionButton, 'floatingActionButton', 'M_FloatingActionButton');
+  }
+})(cash, M.anime);
+;(function ($) {
+  'use strict';
+
+  var _defaults = {
+    // Close when date is selected
+    autoClose: false,
+
+    // the default output format for the input field value
+    format: 'mmm dd, yyyy',
+
+    // Used to create date object from current input string
+    parse: null,
+
+    // The initial date to view when first opened
+    defaultDate: null,
+
+    // Make the `defaultDate` the initial selected value
+    setDefaultDate: false,
+
+    disableWeekends: false,
+
+    disableDayFn: null,
+
+    // First day of week (0: Sunday, 1: Monday etc)
+    firstDay: 0,
+
+    // The earliest date that can be selected
+    minDate: null,
+    // Thelatest date that can be selected
+    maxDate: null,
+
+    // Number of years either side, or array of upper/lower range
+    yearRange: 10,
+
+    // used internally (don't config outside)
+    minYear: 0,
+    maxYear: 9999,
+    minMonth: undefined,
+    maxMonth: undefined,
+
+    startRange: null,
+    endRange: null,
+
+    isRTL: false,
+
+    // Render the month after year in the calendar title
+    showMonthAfterYear: false,
+
+    // Render days of the calendar grid that fall in the next or previous month
+    showDaysInNextAndPreviousMonths: false,
+
+    // Specify a DOM element to render the calendar in
+    container: null,
+
+    // Show clear button
+    showClearBtn: false,
+
+    // internationalization
+    i18n: {
+      cancel: 'Cancel',
+      clear: 'Clear',
+      done: 'Ok',
+      previousMonth: '‹',
+      nextMonth: '›',
+      months: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
+      monthsShort: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],
+      weekdays: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],
+      weekdaysShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],
+      weekdaysAbbrev: ['S', 'M', 'T', 'W', 'T', 'F', 'S']
+    },
+
+    // events array
+    events: [],
+
+    // callback function
+    onSelect: null,
+    onOpen: null,
+    onClose: null,
+    onDraw: null
+  };
+
+  /**
+   * @class
+   *
+   */
+
+  var Datepicker = function (_Component15) {
+    _inherits(Datepicker, _Component15);
+
+    /**
+     * Construct Datepicker instance and set up overlay
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function Datepicker(el, options) {
+      _classCallCheck(this, Datepicker);
+
+      var _this53 = _possibleConstructorReturn(this, (Datepicker.__proto__ || Object.getPrototypeOf(Datepicker)).call(this, Datepicker, el, options));
+
+      _this53.el.M_Datepicker = _this53;
+
+      _this53.options = $.extend({}, Datepicker.defaults, options);
+
+      // make sure i18n defaults are not lost when only few i18n option properties are passed
+      if (!!options && options.hasOwnProperty('i18n') && typeof options.i18n === 'object') {
+        _this53.options.i18n = $.extend({}, Datepicker.defaults.i18n, options.i18n);
+      }
+
+      // Remove time component from minDate and maxDate options
+      if (_this53.options.minDate) _this53.options.minDate.setHours(0, 0, 0, 0);
+      if (_this53.options.maxDate) _this53.options.maxDate.setHours(0, 0, 0, 0);
+
+      _this53.id = M.guid();
+
+      _this53._setupVariables();
+      _this53._insertHTMLIntoDOM();
+      _this53._setupModal();
+
+      _this53._setupEventHandlers();
+
+      if (!_this53.options.defaultDate) {
+        _this53.options.defaultDate = new Date(Date.parse(_this53.el.value));
+      }
+
+      var defDate = _this53.options.defaultDate;
+      if (Datepicker._isDate(defDate)) {
+        if (_this53.options.setDefaultDate) {
+          _this53.setDate(defDate, true);
+          _this53.setInputValue();
+        } else {
+          _this53.gotoDate(defDate);
+        }
+      } else {
+        _this53.gotoDate(new Date());
+      }
+
+      /**
+       * Describes open/close state of datepicker
+       * @type {Boolean}
+       */
+      _this53.isOpen = false;
+      return _this53;
+    }
+
+    _createClass(Datepicker, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        this._removeEventHandlers();
+        this.modal.destroy();
+        $(this.modalEl).remove();
+        this.destroySelects();
+        this.el.M_Datepicker = undefined;
+      }
+    }, {
+      key: "destroySelects",
+      value: function destroySelects() {
+        var oldYearSelect = this.calendarEl.querySelector('.orig-select-year');
+        if (oldYearSelect) {
+          M.FormSelect.getInstance(oldYearSelect).destroy();
+        }
+        var oldMonthSelect = this.calendarEl.querySelector('.orig-select-month');
+        if (oldMonthSelect) {
+          M.FormSelect.getInstance(oldMonthSelect).destroy();
+        }
+      }
+    }, {
+      key: "_insertHTMLIntoDOM",
+      value: function _insertHTMLIntoDOM() {
+        if (this.options.showClearBtn) {
+          $(this.clearBtn).css({ visibility: '' });
+          this.clearBtn.innerHTML = this.options.i18n.clear;
+        }
+
+        this.doneBtn.innerHTML = this.options.i18n.done;
+        this.cancelBtn.innerHTML = this.options.i18n.cancel;
+
+        if (this.options.container) {
+          this.$modalEl.appendTo(this.options.container);
+        } else {
+          this.$modalEl.insertBefore(this.el);
+        }
+      }
+    }, {
+      key: "_setupModal",
+      value: function _setupModal() {
+        var _this54 = this;
+
+        this.modalEl.id = 'modal-' + this.id;
+        this.modal = M.Modal.init(this.modalEl, {
+          onCloseEnd: function () {
+            _this54.isOpen = false;
+          }
+        });
+      }
+    }, {
+      key: "toString",
+      value: function toString(format) {
+        var _this55 = this;
+
+        format = format || this.options.format;
+        if (!Datepicker._isDate(this.date)) {
+          return '';
+        }
+
+        var formatArray = format.split(/(d{1,4}|m{1,4}|y{4}|yy|!.)/g);
+        var formattedDate = formatArray.map(function (label) {
+          if (_this55.formats[label]) {
+            return _this55.formats[label]();
+          }
+
+          return label;
+        }).join('');
+        return formattedDate;
+      }
+    }, {
+      key: "setDate",
+      value: function setDate(date, preventOnSelect) {
+        if (!date) {
+          this.date = null;
+          this._renderDateDisplay();
+          return this.draw();
+        }
+        if (typeof date === 'string') {
+          date = new Date(Date.parse(date));
+        }
+        if (!Datepicker._isDate(date)) {
+          return;
+        }
+
+        var min = this.options.minDate,
+            max = this.options.maxDate;
+
+        if (Datepicker._isDate(min) && date < min) {
+          date = min;
+        } else if (Datepicker._isDate(max) && date > max) {
+          date = max;
+        }
+
+        this.date = new Date(date.getTime());
+
+        this._renderDateDisplay();
+
+        Datepicker._setToStartOfDay(this.date);
+        this.gotoDate(this.date);
+
+        if (!preventOnSelect && typeof this.options.onSelect === 'function') {
+          this.options.onSelect.call(this, this.date);
+        }
+      }
+    }, {
+      key: "setInputValue",
+      value: function setInputValue() {
+        this.el.value = this.toString();
+        this.$el.trigger('change', { firedBy: this });
+      }
+    }, {
+      key: "_renderDateDisplay",
+      value: function _renderDateDisplay() {
+        var displayDate = Datepicker._isDate(this.date) ? this.date : new Date();
+        var i18n = this.options.i18n;
+        var day = i18n.weekdaysShort[displayDate.getDay()];
+        var month = i18n.monthsShort[displayDate.getMonth()];
+        var date = displayDate.getDate();
+        this.yearTextEl.innerHTML = displayDate.getFullYear();
+        this.dateTextEl.innerHTML = day + ", " + month + " " + date;
+      }
+
+      /**
+       * change view to a specific date
+       */
+
+    }, {
+      key: "gotoDate",
+      value: function gotoDate(date) {
+        var newCalendar = true;
+
+        if (!Datepicker._isDate(date)) {
+          return;
+        }
+
+        if (this.calendars) {
+          var firstVisibleDate = new Date(this.calendars[0].year, this.calendars[0].month, 1),
+              lastVisibleDate = new Date(this.calendars[this.calendars.length - 1].year, this.calendars[this.calendars.length - 1].month, 1),
+              visibleDate = date.getTime();
+          // get the end of the month
+          lastVisibleDate.setMonth(lastVisibleDate.getMonth() + 1);
+          lastVisibleDate.setDate(lastVisibleDate.getDate() - 1);
+          newCalendar = visibleDate < firstVisibleDate.getTime() || lastVisibleDate.getTime() < visibleDate;
+        }
+
+        if (newCalendar) {
+          this.calendars = [{
+            month: date.getMonth(),
+            year: date.getFullYear()
+          }];
+        }
+
+        this.adjustCalendars();
+      }
+    }, {
+      key: "adjustCalendars",
+      value: function adjustCalendars() {
+        this.calendars[0] = this.adjustCalendar(this.calendars[0]);
+        this.draw();
+      }
+    }, {
+      key: "adjustCalendar",
+      value: function adjustCalendar(calendar) {
+        if (calendar.month < 0) {
+          calendar.year -= Math.ceil(Math.abs(calendar.month) / 12);
+          calendar.month += 12;
+        }
+        if (calendar.month > 11) {
+          calendar.year += Math.floor(Math.abs(calendar.month) / 12);
+          calendar.month -= 12;
+        }
+        return calendar;
+      }
+    }, {
+      key: "nextMonth",
+      value: function nextMonth() {
+        this.calendars[0].month++;
+        this.adjustCalendars();
+      }
+    }, {
+      key: "prevMonth",
+      value: function prevMonth() {
+        this.calendars[0].month--;
+        this.adjustCalendars();
+      }
+    }, {
+      key: "render",
+      value: function render(year, month, randId) {
+        var opts = this.options,
+            now = new Date(),
+            days = Datepicker._getDaysInMonth(year, month),
+            before = new Date(year, month, 1).getDay(),
+            data = [],
+            row = [];
+        Datepicker._setToStartOfDay(now);
+        if (opts.firstDay > 0) {
+          before -= opts.firstDay;
+          if (before < 0) {
+            before += 7;
+          }
+        }
+        var previousMonth = month === 0 ? 11 : month - 1,
+            nextMonth = month === 11 ? 0 : month + 1,
+            yearOfPreviousMonth = month === 0 ? year - 1 : year,
+            yearOfNextMonth = month === 11 ? year + 1 : year,
+            daysInPreviousMonth = Datepicker._getDaysInMonth(yearOfPreviousMonth, previousMonth);
+        var cells = days + before,
+            after = cells;
+        while (after > 7) {
+          after -= 7;
+        }
+        cells += 7 - after;
+        var isWeekSelected = false;
+        for (var i = 0, r = 0; i < cells; i++) {
+          var day = new Date(year, month, 1 + (i - before)),
+              isSelected = Datepicker._isDate(this.date) ? Datepicker._compareDates(day, this.date) : false,
+              isToday = Datepicker._compareDates(day, now),
+              hasEvent = opts.events.indexOf(day.toDateString()) !== -1 ? true : false,
+              isEmpty = i < before || i >= days + before,
+              dayNumber = 1 + (i - before),
+              monthNumber = month,
+              yearNumber = year,
+              isStartRange = opts.startRange && Datepicker._compareDates(opts.startRange, day),
+              isEndRange = opts.endRange && Datepicker._compareDates(opts.endRange, day),
+              isInRange = opts.startRange && opts.endRange && opts.startRange < day && day < opts.endRange,
+              isDisabled = opts.minDate && day < opts.minDate || opts.maxDate && day > opts.maxDate || opts.disableWeekends && Datepicker._isWeekend(day) || opts.disableDayFn && opts.disableDayFn(day);
+
+          if (isEmpty) {
+            if (i < before) {
+              dayNumber = daysInPreviousMonth + dayNumber;
+              monthNumber = previousMonth;
+              yearNumber = yearOfPreviousMonth;
+            } else {
+              dayNumber = dayNumber - days;
+              monthNumber = nextMonth;
+              yearNumber = yearOfNextMonth;
+            }
+          }
+
+          var dayConfig = {
+            day: dayNumber,
+            month: monthNumber,
+            year: yearNumber,
+            hasEvent: hasEvent,
+            isSelected: isSelected,
+            isToday: isToday,
+            isDisabled: isDisabled,
+            isEmpty: isEmpty,
+            isStartRange: isStartRange,
+            isEndRange: isEndRange,
+            isInRange: isInRange,
+            showDaysInNextAndPreviousMonths: opts.showDaysInNextAndPreviousMonths
+          };
+
+          row.push(this.renderDay(dayConfig));
+
+          if (++r === 7) {
+            data.push(this.renderRow(row, opts.isRTL, isWeekSelected));
+            row = [];
+            r = 0;
+            isWeekSelected = false;
+          }
+        }
+        return this.renderTable(opts, data, randId);
+      }
+    }, {
+      key: "renderDay",
+      value: function renderDay(opts) {
+        var arr = [];
+        var ariaSelected = 'false';
+        if (opts.isEmpty) {
+          if (opts.showDaysInNextAndPreviousMonths) {
+            arr.push('is-outside-current-month');
+            arr.push('is-selection-disabled');
+          } else {
+            return '<td class="is-empty"></td>';
+          }
+        }
+        if (opts.isDisabled) {
+          arr.push('is-disabled');
+        }
+
+        if (opts.isToday) {
+          arr.push('is-today');
+        }
+        if (opts.isSelected) {
+          arr.push('is-selected');
+          ariaSelected = 'true';
+        }
+        if (opts.hasEvent) {
+          arr.push('has-event');
+        }
+        if (opts.isInRange) {
+          arr.push('is-inrange');
+        }
+        if (opts.isStartRange) {
+          arr.push('is-startrange');
+        }
+        if (opts.isEndRange) {
+          arr.push('is-endrange');
+        }
+        return "<td data-day=\"" + opts.day + "\" class=\"" + arr.join(' ') + "\" aria-selected=\"" + ariaSelected + "\">" + ("<button class=\"datepicker-day-button\" type=\"button\" data-year=\"" + opts.year + "\" data-month=\"" + opts.month + "\" data-day=\"" + opts.day + "\">" + opts.day + "</button>") + '</td>';
+      }
+    }, {
+      key: "renderRow",
+      value: function renderRow(days, isRTL, isRowSelected) {
+        return '<tr class="datepicker-row' + (isRowSelected ? ' is-selected' : '') + '">' + (isRTL ? days.reverse() : days).join('') + '</tr>';
+      }
+    }, {
+      key: "renderTable",
+      value: function renderTable(opts, data, randId) {
+        return '<div class="datepicker-table-wrapper"><table cellpadding="0" cellspacing="0" class="datepicker-table" role="grid" aria-labelledby="' + randId + '">' + this.renderHead(opts) + this.renderBody(data) + '</table></div>';
+      }
+    }, {
+      key: "renderHead",
+      value: function renderHead(opts) {
+        var i = void 0,
+            arr = [];
+        for (i = 0; i < 7; i++) {
+          arr.push("<th scope=\"col\"><abbr title=\"" + this.renderDayName(opts, i) + "\">" + this.renderDayName(opts, i, true) + "</abbr></th>");
+        }
+        return '<thead><tr>' + (opts.isRTL ? arr.reverse() : arr).join('') + '</tr></thead>';
+      }
+    }, {
+      key: "renderBody",
+      value: function renderBody(rows) {
+        return '<tbody>' + rows.join('') + '</tbody>';
+      }
+    }, {
+      key: "renderTitle",
+      value: function renderTitle(instance, c, year, month, refYear, randId) {
+        var i = void 0,
+            j = void 0,
+            arr = void 0,
+            opts = this.options,
+            isMinYear = year === opts.minYear,
+            isMaxYear = year === opts.maxYear,
+            html = '<div id="' + randId + '" class="datepicker-controls" role="heading" aria-live="assertive">',
+            monthHtml = void 0,
+            yearHtml = void 0,
+            prev = true,
+            next = true;
+
+        for (arr = [], i = 0; i < 12; i++) {
+          arr.push('<option value="' + (year === refYear ? i - c : 12 + i - c) + '"' + (i === month ? ' selected="selected"' : '') + (isMinYear && i < opts.minMonth || isMaxYear && i > opts.maxMonth ? 'disabled="disabled"' : '') + '>' + opts.i18n.months[i] + '</option>');
+        }
+
+        monthHtml = '<select class="datepicker-select orig-select-month" tabindex="-1">' + arr.join('') + '</select>';
+
+        if ($.isArray(opts.yearRange)) {
+          i = opts.yearRange[0];
+          j = opts.yearRange[1] + 1;
+        } else {
+          i = year - opts.yearRange;
+          j = 1 + year + opts.yearRange;
+        }
+
+        for (arr = []; i < j && i <= opts.maxYear; i++) {
+          if (i >= opts.minYear) {
+            arr.push("<option value=\"" + i + "\" " + (i === year ? 'selected="selected"' : '') + ">" + i + "</option>");
+          }
+        }
+
+        yearHtml = "<select class=\"datepicker-select orig-select-year\" tabindex=\"-1\">" + arr.join('') + "</select>";
+
+        var leftArrow = '<svg fill="#000000" height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="M15.41 16.09l-4.58-4.59 4.58-4.59L14 5.5l-6 6 6 6z"/><path d="M0-.5h24v24H0z" fill="none"/></svg>';
+        html += "<button class=\"month-prev" + (prev ? '' : ' is-disabled') + "\" type=\"button\">" + leftArrow + "</button>";
+
+        html += '<div class="selects-container">';
+        if (opts.showMonthAfterYear) {
+          html += yearHtml + monthHtml;
+        } else {
+          html += monthHtml + yearHtml;
+        }
+        html += '</div>';
+
+        if (isMinYear && (month === 0 || opts.minMonth >= month)) {
+          prev = false;
+        }
+
+        if (isMaxYear && (month === 11 || opts.maxMonth <= month)) {
+          next = false;
+        }
+
+        var rightArrow = '<svg fill="#000000" height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="M8.59 16.34l4.58-4.59-4.58-4.59L10 5.75l6 6-6 6z"/><path d="M0-.25h24v24H0z" fill="none"/></svg>';
+        html += "<button class=\"month-next" + (next ? '' : ' is-disabled') + "\" type=\"button\">" + rightArrow + "</button>";
+
+        return html += '</div>';
+      }
+
+      /**
+       * refresh the HTML
+       */
+
+    }, {
+      key: "draw",
+      value: function draw(force) {
+        if (!this.isOpen && !force) {
+          return;
+        }
+        var opts = this.options,
+            minYear = opts.minYear,
+            maxYear = opts.maxYear,
+            minMonth = opts.minMonth,
+            maxMonth = opts.maxMonth,
+            html = '',
+            randId = void 0;
+
+        if (this._y <= minYear) {
+          this._y = minYear;
+          if (!isNaN(minMonth) && this._m < minMonth) {
+            this._m = minMonth;
+          }
+        }
+        if (this._y >= maxYear) {
+          this._y = maxYear;
+          if (!isNaN(maxMonth) && this._m > maxMonth) {
+            this._m = maxMonth;
+          }
+        }
+
+        randId = 'datepicker-title-' + Math.random().toString(36).replace(/[^a-z]+/g, '').substr(0, 2);
+
+        for (var c = 0; c < 1; c++) {
+          this._renderDateDisplay();
+          html += this.renderTitle(this, c, this.calendars[c].year, this.calendars[c].month, this.calendars[0].year, randId) + this.render(this.calendars[c].year, this.calendars[c].month, randId);
+        }
+
+        this.destroySelects();
+
+        this.calendarEl.innerHTML = html;
+
+        // Init Materialize Select
+        var yearSelect = this.calendarEl.querySelector('.orig-select-year');
+        var monthSelect = this.calendarEl.querySelector('.orig-select-month');
+        M.FormSelect.init(yearSelect, {
+          classes: 'select-year',
+          dropdownOptions: { container: document.body, constrainWidth: false }
+        });
+        M.FormSelect.init(monthSelect, {
+          classes: 'select-month',
+          dropdownOptions: { container: document.body, constrainWidth: false }
+        });
+
+        // Add change handlers for select
+        yearSelect.addEventListener('change', this._handleYearChange.bind(this));
+        monthSelect.addEventListener('change', this._handleMonthChange.bind(this));
+
+        if (typeof this.options.onDraw === 'function') {
+          this.options.onDraw(this);
+        }
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        this._handleInputKeydownBound = this._handleInputKeydown.bind(this);
+        this._handleInputClickBound = this._handleInputClick.bind(this);
+        this._handleInputChangeBound = this._handleInputChange.bind(this);
+        this._handleCalendarClickBound = this._handleCalendarClick.bind(this);
+        this._finishSelectionBound = this._finishSelection.bind(this);
+        this._handleMonthChange = this._handleMonthChange.bind(this);
+        this._closeBound = this.close.bind(this);
+
+        this.el.addEventListener('click', this._handleInputClickBound);
+        this.el.addEventListener('keydown', this._handleInputKeydownBound);
+        this.el.addEventListener('change', this._handleInputChangeBound);
+        this.calendarEl.addEventListener('click', this._handleCalendarClickBound);
+        this.doneBtn.addEventListener('click', this._finishSelectionBound);
+        this.cancelBtn.addEventListener('click', this._closeBound);
+
+        if (this.options.showClearBtn) {
+          this._handleClearClickBound = this._handleClearClick.bind(this);
+          this.clearBtn.addEventListener('click', this._handleClearClickBound);
+        }
+      }
+    }, {
+      key: "_setupVariables",
+      value: function _setupVariables() {
+        var _this56 = this;
+
+        this.$modalEl = $(Datepicker._template);
+        this.modalEl = this.$modalEl[0];
+
+        this.calendarEl = this.modalEl.querySelector('.datepicker-calendar');
+
+        this.yearTextEl = this.modalEl.querySelector('.year-text');
+        this.dateTextEl = this.modalEl.querySelector('.date-text');
+        if (this.options.showClearBtn) {
+          this.clearBtn = this.modalEl.querySelector('.datepicker-clear');
+        }
+        this.doneBtn = this.modalEl.querySelector('.datepicker-done');
+        this.cancelBtn = this.modalEl.querySelector('.datepicker-cancel');
+
+        this.formats = {
+          d: function () {
+            return _this56.date.getDate();
+          },
+          dd: function () {
+            var d = _this56.date.getDate();
+            return (d < 10 ? '0' : '') + d;
+          },
+          ddd: function () {
+            return _this56.options.i18n.weekdaysShort[_this56.date.getDay()];
+          },
+          dddd: function () {
+            return _this56.options.i18n.weekdays[_this56.date.getDay()];
+          },
+          m: function () {
+            return _this56.date.getMonth() + 1;
+          },
+          mm: function () {
+            var m = _this56.date.getMonth() + 1;
+            return (m < 10 ? '0' : '') + m;
+          },
+          mmm: function () {
+            return _this56.options.i18n.monthsShort[_this56.date.getMonth()];
+          },
+          mmmm: function () {
+            return _this56.options.i18n.months[_this56.date.getMonth()];
+          },
+          yy: function () {
+            return ('' + _this56.date.getFullYear()).slice(2);
+          },
+          yyyy: function () {
+            return _this56.date.getFullYear();
+          }
+        };
+      }
+
+      /**
+       * Remove Event Handlers
+       */
+
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        this.el.removeEventListener('click', this._handleInputClickBound);
+        this.el.removeEventListener('keydown', this._handleInputKeydownBound);
+        this.el.removeEventListener('change', this._handleInputChangeBound);
+        this.calendarEl.removeEventListener('click', this._handleCalendarClickBound);
+      }
+    }, {
+      key: "_handleInputClick",
+      value: function _handleInputClick() {
+        this.open();
+      }
+    }, {
+      key: "_handleInputKeydown",
+      value: function _handleInputKeydown(e) {
+        if (e.which === M.keys.ENTER) {
+          e.preventDefault();
+          this.open();
+        }
+      }
+    }, {
+      key: "_handleCalendarClick",
+      value: function _handleCalendarClick(e) {
+        if (!this.isOpen) {
+          return;
+        }
+
+        var $target = $(e.target);
+        if (!$target.hasClass('is-disabled')) {
+          if ($target.hasClass('datepicker-day-button') && !$target.hasClass('is-empty') && !$target.parent().hasClass('is-disabled')) {
+            this.setDate(new Date(e.target.getAttribute('data-year'), e.target.getAttribute('data-month'), e.target.getAttribute('data-day')));
+            if (this.options.autoClose) {
+              this._finishSelection();
+            }
+          } else if ($target.closest('.month-prev').length) {
+            this.prevMonth();
+          } else if ($target.closest('.month-next').length) {
+            this.nextMonth();
+          }
+        }
+      }
+    }, {
+      key: "_handleClearClick",
+      value: function _handleClearClick() {
+        this.date = null;
+        this.setInputValue();
+        this.close();
+      }
+    }, {
+      key: "_handleMonthChange",
+      value: function _handleMonthChange(e) {
+        this.gotoMonth(e.target.value);
+      }
+    }, {
+      key: "_handleYearChange",
+      value: function _handleYearChange(e) {
+        this.gotoYear(e.target.value);
+      }
+
+      /**
+       * change view to a specific month (zero-index, e.g. 0: January)
+       */
+
+    }, {
+      key: "gotoMonth",
+      value: function gotoMonth(month) {
+        if (!isNaN(month)) {
+          this.calendars[0].month = parseInt(month, 10);
+          this.adjustCalendars();
+        }
+      }
+
+      /**
+       * change view to a specific full year (e.g. "2012")
+       */
+
+    }, {
+      key: "gotoYear",
+      value: function gotoYear(year) {
+        if (!isNaN(year)) {
+          this.calendars[0].year = parseInt(year, 10);
+          this.adjustCalendars();
+        }
+      }
+    }, {
+      key: "_handleInputChange",
+      value: function _handleInputChange(e) {
+        var date = void 0;
+
+        // Prevent change event from being fired when triggered by the plugin
+        if (e.firedBy === this) {
+          return;
+        }
+        if (this.options.parse) {
+          date = this.options.parse(this.el.value, this.options.format);
+        } else {
+          date = new Date(Date.parse(this.el.value));
+        }
+
+        if (Datepicker._isDate(date)) {
+          this.setDate(date);
+        }
+      }
+    }, {
+      key: "renderDayName",
+      value: function renderDayName(opts, day, abbr) {
+        day += opts.firstDay;
+        while (day >= 7) {
+          day -= 7;
+        }
+        return abbr ? opts.i18n.weekdaysAbbrev[day] : opts.i18n.weekdays[day];
+      }
+
+      /**
+       * Set input value to the selected date and close Datepicker
+       */
+
+    }, {
+      key: "_finishSelection",
+      value: function _finishSelection() {
+        this.setInputValue();
+        this.close();
+      }
+
+      /**
+       * Open Datepicker
+       */
+
+    }, {
+      key: "open",
+      value: function open() {
+        if (this.isOpen) {
+          return;
+        }
+
+        this.isOpen = true;
+        if (typeof this.options.onOpen === 'function') {
+          this.options.onOpen.call(this);
+        }
+        this.draw();
+        this.modal.open();
+        return this;
+      }
+
+      /**
+       * Close Datepicker
+       */
+
+    }, {
+      key: "close",
+      value: function close() {
+        if (!this.isOpen) {
+          return;
+        }
+
+        this.isOpen = false;
+        if (typeof this.options.onClose === 'function') {
+          this.options.onClose.call(this);
+        }
+        this.modal.close();
+        return this;
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(Datepicker.__proto__ || Object.getPrototypeOf(Datepicker), "init", this).call(this, this, els, options);
+      }
+    }, {
+      key: "_isDate",
+      value: function _isDate(obj) {
+        return (/Date/.test(Object.prototype.toString.call(obj)) && !isNaN(obj.getTime())
+        );
+      }
+    }, {
+      key: "_isWeekend",
+      value: function _isWeekend(date) {
+        var day = date.getDay();
+        return day === 0 || day === 6;
+      }
+    }, {
+      key: "_setToStartOfDay",
+      value: function _setToStartOfDay(date) {
+        if (Datepicker._isDate(date)) date.setHours(0, 0, 0, 0);
+      }
+    }, {
+      key: "_getDaysInMonth",
+      value: function _getDaysInMonth(year, month) {
+        return [31, Datepicker._isLeapYear(year) ? 29 : 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31][month];
+      }
+    }, {
+      key: "_isLeapYear",
+      value: function _isLeapYear(year) {
+        // solution by Matti Virkkunen: http://stackoverflow.com/a/4881951
+        return year % 4 === 0 && year % 100 !== 0 || year % 400 === 0;
+      }
+    }, {
+      key: "_compareDates",
+      value: function _compareDates(a, b) {
+        // weak date comparison (use setToStartOfDay(date) to ensure correct result)
+        return a.getTime() === b.getTime();
+      }
+    }, {
+      key: "_setToStartOfDay",
+      value: function _setToStartOfDay(date) {
+        if (Datepicker._isDate(date)) date.setHours(0, 0, 0, 0);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Datepicker;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Datepicker;
+  }(Component);
+
+  Datepicker._template = ['<div class= "modal datepicker-modal">', '<div class="modal-content datepicker-container">', '<div class="datepicker-date-display">', '<span class="year-text"></span>', '<span class="date-text"></span>', '</div>', '<div class="datepicker-calendar-container">', '<div class="datepicker-calendar"></div>', '<div class="datepicker-footer">', '<button class="btn-flat datepicker-clear waves-effect" style="visibility: hidden;" type="button"></button>', '<div class="confirmation-btns">', '<button class="btn-flat datepicker-cancel waves-effect" type="button"></button>', '<button class="btn-flat datepicker-done waves-effect" type="button"></button>', '</div>', '</div>', '</div>', '</div>', '</div>'].join('');
+
+  M.Datepicker = Datepicker;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(Datepicker, 'datepicker', 'M_Datepicker');
+  }
+})(cash);
+;(function ($) {
+  'use strict';
+
+  var _defaults = {
+    dialRadius: 135,
+    outerRadius: 105,
+    innerRadius: 70,
+    tickRadius: 20,
+    duration: 350,
+    container: null,
+    defaultTime: 'now', // default time, 'now' or '13:14' e.g.
+    fromNow: 0, // Millisecond offset from the defaultTime
+    showClearBtn: false,
+
+    // internationalization
+    i18n: {
+      cancel: 'Cancel',
+      clear: 'Clear',
+      done: 'Ok'
+    },
+
+    autoClose: false, // auto close when minute is selected
+    twelveHour: true, // change to 12 hour AM/PM clock from 24 hour
+    vibrate: true, // vibrate the device when dragging clock hand
+
+    // Callbacks
+    onOpenStart: null,
+    onOpenEnd: null,
+    onCloseStart: null,
+    onCloseEnd: null,
+    onSelect: null
+  };
+
+  /**
+   * @class
+   *
+   */
+
+  var Timepicker = function (_Component16) {
+    _inherits(Timepicker, _Component16);
+
+    function Timepicker(el, options) {
+      _classCallCheck(this, Timepicker);
+
+      var _this57 = _possibleConstructorReturn(this, (Timepicker.__proto__ || Object.getPrototypeOf(Timepicker)).call(this, Timepicker, el, options));
+
+      _this57.el.M_Timepicker = _this57;
+
+      _this57.options = $.extend({}, Timepicker.defaults, options);
+
+      _this57.id = M.guid();
+      _this57._insertHTMLIntoDOM();
+      _this57._setupModal();
+      _this57._setupVariables();
+      _this57._setupEventHandlers();
+
+      _this57._clockSetup();
+      _this57._pickerSetup();
+      return _this57;
+    }
+
+    _createClass(Timepicker, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        this._removeEventHandlers();
+        this.modal.destroy();
+        $(this.modalEl).remove();
+        this.el.M_Timepicker = undefined;
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        this._handleInputKeydownBound = this._handleInputKeydown.bind(this);
+        this._handleInputClickBound = this._handleInputClick.bind(this);
+        this._handleClockClickStartBound = this._handleClockClickStart.bind(this);
+        this._handleDocumentClickMoveBound = this._handleDocumentClickMove.bind(this);
+        this._handleDocumentClickEndBound = this._handleDocumentClickEnd.bind(this);
+
+        this.el.addEventListener('click', this._handleInputClickBound);
+        this.el.addEventListener('keydown', this._handleInputKeydownBound);
+        this.plate.addEventListener('mousedown', this._handleClockClickStartBound);
+        this.plate.addEventListener('touchstart', this._handleClockClickStartBound);
+
+        $(this.spanHours).on('click', this.showView.bind(this, 'hours'));
+        $(this.spanMinutes).on('click', this.showView.bind(this, 'minutes'));
+      }
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        this.el.removeEventListener('click', this._handleInputClickBound);
+        this.el.removeEventListener('keydown', this._handleInputKeydownBound);
+      }
+    }, {
+      key: "_handleInputClick",
+      value: function _handleInputClick() {
+        this.open();
+      }
+    }, {
+      key: "_handleInputKeydown",
+      value: function _handleInputKeydown(e) {
+        if (e.which === M.keys.ENTER) {
+          e.preventDefault();
+          this.open();
+        }
+      }
+    }, {
+      key: "_handleClockClickStart",
+      value: function _handleClockClickStart(e) {
+        e.preventDefault();
+        var clockPlateBR = this.plate.getBoundingClientRect();
+        var offset = { x: clockPlateBR.left, y: clockPlateBR.top };
+
+        this.x0 = offset.x + this.options.dialRadius;
+        this.y0 = offset.y + this.options.dialRadius;
+        this.moved = false;
+        var clickPos = Timepicker._Pos(e);
+        this.dx = clickPos.x - this.x0;
+        this.dy = clickPos.y - this.y0;
+
+        // Set clock hands
+        this.setHand(this.dx, this.dy, false);
+
+        // Mousemove on document
+        document.addEventListener('mousemove', this._handleDocumentClickMoveBound);
+        document.addEventListener('touchmove', this._handleDocumentClickMoveBound);
+
+        // Mouseup on document
+        document.addEventListener('mouseup', this._handleDocumentClickEndBound);
+        document.addEventListener('touchend', this._handleDocumentClickEndBound);
+      }
+    }, {
+      key: "_handleDocumentClickMove",
+      value: function _handleDocumentClickMove(e) {
+        e.preventDefault();
+        var clickPos = Timepicker._Pos(e);
+        var x = clickPos.x - this.x0;
+        var y = clickPos.y - this.y0;
+        this.moved = true;
+        this.setHand(x, y, false, true);
+      }
+    }, {
+      key: "_handleDocumentClickEnd",
+      value: function _handleDocumentClickEnd(e) {
+        var _this58 = this;
+
+        e.preventDefault();
+        document.removeEventListener('mouseup', this._handleDocumentClickEndBound);
+        document.removeEventListener('touchend', this._handleDocumentClickEndBound);
+        var clickPos = Timepicker._Pos(e);
+        var x = clickPos.x - this.x0;
+        var y = clickPos.y - this.y0;
+        if (this.moved && x === this.dx && y === this.dy) {
+          this.setHand(x, y);
+        }
+
+        if (this.currentView === 'hours') {
+          this.showView('minutes', this.options.duration / 2);
+        } else if (this.options.autoClose) {
+          $(this.minutesView).addClass('timepicker-dial-out');
+          setTimeout(function () {
+            _this58.done();
+          }, this.options.duration / 2);
+        }
+
+        if (typeof this.options.onSelect === 'function') {
+          this.options.onSelect.call(this, this.hours, this.minutes);
+        }
+
+        // Unbind mousemove event
+        document.removeEventListener('mousemove', this._handleDocumentClickMoveBound);
+        document.removeEventListener('touchmove', this._handleDocumentClickMoveBound);
+      }
+    }, {
+      key: "_insertHTMLIntoDOM",
+      value: function _insertHTMLIntoDOM() {
+        this.$modalEl = $(Timepicker._template);
+        this.modalEl = this.$modalEl[0];
+        this.modalEl.id = 'modal-' + this.id;
+
+        // Append popover to input by default
+        var containerEl = document.querySelector(this.options.container);
+        if (this.options.container && !!containerEl) {
+          this.$modalEl.appendTo(containerEl);
+        } else {
+          this.$modalEl.insertBefore(this.el);
+        }
+      }
+    }, {
+      key: "_setupModal",
+      value: function _setupModal() {
+        var _this59 = this;
+
+        this.modal = M.Modal.init(this.modalEl, {
+          onOpenStart: this.options.onOpenStart,
+          onOpenEnd: this.options.onOpenEnd,
+          onCloseStart: this.options.onCloseStart,
+          onCloseEnd: function () {
+            if (typeof _this59.options.onCloseEnd === 'function') {
+              _this59.options.onCloseEnd.call(_this59);
+            }
+            _this59.isOpen = false;
+          }
+        });
+      }
+    }, {
+      key: "_setupVariables",
+      value: function _setupVariables() {
+        this.currentView = 'hours';
+        this.vibrate = navigator.vibrate ? 'vibrate' : navigator.webkitVibrate ? 'webkitVibrate' : null;
+
+        this._canvas = this.modalEl.querySelector('.timepicker-canvas');
+        this.plate = this.modalEl.querySelector('.timepicker-plate');
+
+        this.hoursView = this.modalEl.querySelector('.timepicker-hours');
+        this.minutesView = this.modalEl.querySelector('.timepicker-minutes');
+        this.spanHours = this.modalEl.querySelector('.timepicker-span-hours');
+        this.spanMinutes = this.modalEl.querySelector('.timepicker-span-minutes');
+        this.spanAmPm = this.modalEl.querySelector('.timepicker-span-am-pm');
+        this.footer = this.modalEl.querySelector('.timepicker-footer');
+        this.amOrPm = 'PM';
+      }
+    }, {
+      key: "_pickerSetup",
+      value: function _pickerSetup() {
+        var $clearBtn = $("<button class=\"btn-flat timepicker-clear waves-effect\" style=\"visibility: hidden;\" type=\"button\" tabindex=\"" + (this.options.twelveHour ? '3' : '1') + "\">" + this.options.i18n.clear + "</button>").appendTo(this.footer).on('click', this.clear.bind(this));
+        if (this.options.showClearBtn) {
+          $clearBtn.css({ visibility: '' });
+        }
+
+        var confirmationBtnsContainer = $('<div class="confirmation-btns"></div>');
+        $('<button class="btn-flat timepicker-close waves-effect" type="button" tabindex="' + (this.options.twelveHour ? '3' : '1') + '">' + this.options.i18n.cancel + '</button>').appendTo(confirmationBtnsContainer).on('click', this.close.bind(this));
+        $('<button class="btn-flat timepicker-close waves-effect" type="button" tabindex="' + (this.options.twelveHour ? '3' : '1') + '">' + this.options.i18n.done + '</button>').appendTo(confirmationBtnsContainer).on('click', this.done.bind(this));
+        confirmationBtnsContainer.appendTo(this.footer);
+      }
+    }, {
+      key: "_clockSetup",
+      value: function _clockSetup() {
+        if (this.options.twelveHour) {
+          this.$amBtn = $('<div class="am-btn">AM</div>');
+          this.$pmBtn = $('<div class="pm-btn">PM</div>');
+          this.$amBtn.on('click', this._handleAmPmClick.bind(this)).appendTo(this.spanAmPm);
+          this.$pmBtn.on('click', this._handleAmPmClick.bind(this)).appendTo(this.spanAmPm);
+        }
+
+        this._buildHoursView();
+        this._buildMinutesView();
+        this._buildSVGClock();
+      }
+    }, {
+      key: "_buildSVGClock",
+      value: function _buildSVGClock() {
+        // Draw clock hands and others
+        var dialRadius = this.options.dialRadius;
+        var tickRadius = this.options.tickRadius;
+        var diameter = dialRadius * 2;
+
+        var svg = Timepicker._createSVGEl('svg');
+        svg.setAttribute('class', 'timepicker-svg');
+        svg.setAttribute('width', diameter);
+        svg.setAttribute('height', diameter);
+        var g = Timepicker._createSVGEl('g');
+        g.setAttribute('transform', 'translate(' + dialRadius + ',' + dialRadius + ')');
+        var bearing = Timepicker._createSVGEl('circle');
+        bearing.setAttribute('class', 'timepicker-canvas-bearing');
+        bearing.setAttribute('cx', 0);
+        bearing.setAttribute('cy', 0);
+        bearing.setAttribute('r', 4);
+        var hand = Timepicker._createSVGEl('line');
+        hand.setAttribute('x1', 0);
+        hand.setAttribute('y1', 0);
+        var bg = Timepicker._createSVGEl('circle');
+        bg.setAttribute('class', 'timepicker-canvas-bg');
+        bg.setAttribute('r', tickRadius);
+        g.appendChild(hand);
+        g.appendChild(bg);
+        g.appendChild(bearing);
+        svg.appendChild(g);
+        this._canvas.appendChild(svg);
+
+        this.hand = hand;
+        this.bg = bg;
+        this.bearing = bearing;
+        this.g = g;
+      }
+    }, {
+      key: "_buildHoursView",
+      value: function _buildHoursView() {
+        var $tick = $('<div class="timepicker-tick"></div>');
+        // Hours view
+        if (this.options.twelveHour) {
+          for (var i = 1; i < 13; i += 1) {
+            var tick = $tick.clone();
+            var radian = i / 6 * Math.PI;
+            var radius = this.options.outerRadius;
+            tick.css({
+              left: this.options.dialRadius + Math.sin(radian) * radius - this.options.tickRadius + 'px',
+              top: this.options.dialRadius - Math.cos(radian) * radius - this.options.tickRadius + 'px'
+            });
+            tick.html(i === 0 ? '00' : i);
+            this.hoursView.appendChild(tick[0]);
+            // tick.on(mousedownEvent, mousedown);
+          }
+        } else {
+          for (var _i2 = 0; _i2 < 24; _i2 += 1) {
+            var _tick = $tick.clone();
+            var _radian = _i2 / 6 * Math.PI;
+            var inner = _i2 > 0 && _i2 < 13;
+            var _radius = inner ? this.options.innerRadius : this.options.outerRadius;
+            _tick.css({
+              left: this.options.dialRadius + Math.sin(_radian) * _radius - this.options.tickRadius + 'px',
+              top: this.options.dialRadius - Math.cos(_radian) * _radius - this.options.tickRadius + 'px'
+            });
+            _tick.html(_i2 === 0 ? '00' : _i2);
+            this.hoursView.appendChild(_tick[0]);
+            // tick.on(mousedownEvent, mousedown);
+          }
+        }
+      }
+    }, {
+      key: "_buildMinutesView",
+      value: function _buildMinutesView() {
+        var $tick = $('<div class="timepicker-tick"></div>');
+        // Minutes view
+        for (var i = 0; i < 60; i += 5) {
+          var tick = $tick.clone();
+          var radian = i / 30 * Math.PI;
+          tick.css({
+            left: this.options.dialRadius + Math.sin(radian) * this.options.outerRadius - this.options.tickRadius + 'px',
+            top: this.options.dialRadius - Math.cos(radian) * this.options.outerRadius - this.options.tickRadius + 'px'
+          });
+          tick.html(Timepicker._addLeadingZero(i));
+          this.minutesView.appendChild(tick[0]);
+        }
+      }
+    }, {
+      key: "_handleAmPmClick",
+      value: function _handleAmPmClick(e) {
+        var $btnClicked = $(e.target);
+        this.amOrPm = $btnClicked.hasClass('am-btn') ? 'AM' : 'PM';
+        this._updateAmPmView();
+      }
+    }, {
+      key: "_updateAmPmView",
+      value: function _updateAmPmView() {
+        if (this.options.twelveHour) {
+          this.$amBtn.toggleClass('text-primary', this.amOrPm === 'AM');
+          this.$pmBtn.toggleClass('text-primary', this.amOrPm === 'PM');
+        }
+      }
+    }, {
+      key: "_updateTimeFromInput",
+      value: function _updateTimeFromInput() {
+        // Get the time
+        var value = ((this.el.value || this.options.defaultTime || '') + '').split(':');
+        if (this.options.twelveHour && !(typeof value[1] === 'undefined')) {
+          if (value[1].toUpperCase().indexOf('AM') > 0) {
+            this.amOrPm = 'AM';
+          } else {
+            this.amOrPm = 'PM';
+          }
+          value[1] = value[1].replace('AM', '').replace('PM', '');
+        }
+        if (value[0] === 'now') {
+          var now = new Date(+new Date() + this.options.fromNow);
+          value = [now.getHours(), now.getMinutes()];
+          if (this.options.twelveHour) {
+            this.amOrPm = value[0] >= 12 && value[0] < 24 ? 'PM' : 'AM';
+          }
+        }
+        this.hours = +value[0] || 0;
+        this.minutes = +value[1] || 0;
+        this.spanHours.innerHTML = this.hours;
+        this.spanMinutes.innerHTML = Timepicker._addLeadingZero(this.minutes);
+
+        this._updateAmPmView();
+      }
+    }, {
+      key: "showView",
+      value: function showView(view, delay) {
+        if (view === 'minutes' && $(this.hoursView).css('visibility') === 'visible') {
+          // raiseCallback(this.options.beforeHourSelect);
+        }
+        var isHours = view === 'hours',
+            nextView = isHours ? this.hoursView : this.minutesView,
+            hideView = isHours ? this.minutesView : this.hoursView;
+        this.currentView = view;
+
+        $(this.spanHours).toggleClass('text-primary', isHours);
+        $(this.spanMinutes).toggleClass('text-primary', !isHours);
+
+        // Transition view
+        hideView.classList.add('timepicker-dial-out');
+        $(nextView).css('visibility', 'visible').removeClass('timepicker-dial-out');
+
+        // Reset clock hand
+        this.resetClock(delay);
+
+        // After transitions ended
+        clearTimeout(this.toggleViewTimer);
+        this.toggleViewTimer = setTimeout(function () {
+          $(hideView).css('visibility', 'hidden');
+        }, this.options.duration);
+      }
+    }, {
+      key: "resetClock",
+      value: function resetClock(delay) {
+        var view = this.currentView,
+            value = this[view],
+            isHours = view === 'hours',
+            unit = Math.PI / (isHours ? 6 : 30),
+            radian = value * unit,
+            radius = isHours && value > 0 && value < 13 ? this.options.innerRadius : this.options.outerRadius,
+            x = Math.sin(radian) * radius,
+            y = -Math.cos(radian) * radius,
+            self = this;
+
+        if (delay) {
+          $(this.canvas).addClass('timepicker-canvas-out');
+          setTimeout(function () {
+            $(self.canvas).removeClass('timepicker-canvas-out');
+            self.setHand(x, y);
+          }, delay);
+        } else {
+          this.setHand(x, y);
+        }
+      }
+    }, {
+      key: "setHand",
+      value: function setHand(x, y, roundBy5) {
+        var _this60 = this;
+
+        var radian = Math.atan2(x, -y),
+            isHours = this.currentView === 'hours',
+            unit = Math.PI / (isHours || roundBy5 ? 6 : 30),
+            z = Math.sqrt(x * x + y * y),
+            inner = isHours && z < (this.options.outerRadius + this.options.innerRadius) / 2,
+            radius = inner ? this.options.innerRadius : this.options.outerRadius;
+
+        if (this.options.twelveHour) {
+          radius = this.options.outerRadius;
+        }
+
+        // Radian should in range [0, 2PI]
+        if (radian < 0) {
+          radian = Math.PI * 2 + radian;
+        }
+
+        // Get the round value
+        var value = Math.round(radian / unit);
+
+        // Get the round radian
+        radian = value * unit;
+
+        // Correct the hours or minutes
+        if (this.options.twelveHour) {
+          if (isHours) {
+            if (value === 0) value = 12;
+          } else {
+            if (roundBy5) value *= 5;
+            if (value === 60) value = 0;
+          }
+        } else {
+          if (isHours) {
+            if (value === 12) {
+              value = 0;
+            }
+            value = inner ? value === 0 ? 12 : value : value === 0 ? 0 : value + 12;
+          } else {
+            if (roundBy5) {
+              value *= 5;
+            }
+            if (value === 60) {
+              value = 0;
+            }
+          }
+        }
+
+        // Once hours or minutes changed, vibrate the device
+        if (this[this.currentView] !== value) {
+          if (this.vibrate && this.options.vibrate) {
+            // Do not vibrate too frequently
+            if (!this.vibrateTimer) {
+              navigator[this.vibrate](10);
+              this.vibrateTimer = setTimeout(function () {
+                _this60.vibrateTimer = null;
+              }, 100);
+            }
+          }
+        }
+
+        this[this.currentView] = value;
+        if (isHours) {
+          this['spanHours'].innerHTML = value;
+        } else {
+          this['spanMinutes'].innerHTML = Timepicker._addLeadingZero(value);
+        }
+
+        // Set clock hand and others' position
+        var cx1 = Math.sin(radian) * (radius - this.options.tickRadius),
+            cy1 = -Math.cos(radian) * (radius - this.options.tickRadius),
+            cx2 = Math.sin(radian) * radius,
+            cy2 = -Math.cos(radian) * radius;
+        this.hand.setAttribute('x2', cx1);
+        this.hand.setAttribute('y2', cy1);
+        this.bg.setAttribute('cx', cx2);
+        this.bg.setAttribute('cy', cy2);
+      }
+    }, {
+      key: "open",
+      value: function open() {
+        if (this.isOpen) {
+          return;
+        }
+
+        this.isOpen = true;
+        this._updateTimeFromInput();
+        this.showView('hours');
+
+        this.modal.open();
+      }
+    }, {
+      key: "close",
+      value: function close() {
+        if (!this.isOpen) {
+          return;
+        }
+
+        this.isOpen = false;
+        this.modal.close();
+      }
+
+      /**
+       * Finish timepicker selection.
+       */
+
+    }, {
+      key: "done",
+      value: function done(e, clearValue) {
+        // Set input value
+        var last = this.el.value;
+        var value = clearValue ? '' : Timepicker._addLeadingZero(this.hours) + ':' + Timepicker._addLeadingZero(this.minutes);
+        this.time = value;
+        if (!clearValue && this.options.twelveHour) {
+          value = value + " " + this.amOrPm;
+        }
+        this.el.value = value;
+
+        // Trigger change event
+        if (value !== last) {
+          this.$el.trigger('change');
+        }
+
+        this.close();
+        this.el.focus();
+      }
+    }, {
+      key: "clear",
+      value: function clear() {
+        this.done(null, true);
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(Timepicker.__proto__ || Object.getPrototypeOf(Timepicker), "init", this).call(this, this, els, options);
+      }
+    }, {
+      key: "_addLeadingZero",
+      value: function _addLeadingZero(num) {
+        return (num < 10 ? '0' : '') + num;
+      }
+    }, {
+      key: "_createSVGEl",
+      value: function _createSVGEl(name) {
+        var svgNS = 'http://www.w3.org/2000/svg';
+        return document.createElementNS(svgNS, name);
+      }
+
+      /**
+       * @typedef {Object} Point
+       * @property {number} x The X Coordinate
+       * @property {number} y The Y Coordinate
+       */
+
+      /**
+       * Get x position of mouse or touch event
+       * @param {Event} e
+       * @return {Point} x and y location
+       */
+
+    }, {
+      key: "_Pos",
+      value: function _Pos(e) {
+        if (e.targetTouches && e.targetTouches.length >= 1) {
+          return { x: e.targetTouches[0].clientX, y: e.targetTouches[0].clientY };
+        }
+        // mouse event
+        return { x: e.clientX, y: e.clientY };
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Timepicker;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Timepicker;
+  }(Component);
+
+  Timepicker._template = ['<div class= "modal timepicker-modal">', '<div class="modal-content timepicker-container">', '<div class="timepicker-digital-display">', '<div class="timepicker-text-container">', '<div class="timepicker-display-column">', '<span class="timepicker-span-hours text-primary"></span>', ':', '<span class="timepicker-span-minutes"></span>', '</div>', '<div class="timepicker-display-column timepicker-display-am-pm">', '<div class="timepicker-span-am-pm"></div>', '</div>', '</div>', '</div>', '<div class="timepicker-analog-display">', '<div class="timepicker-plate">', '<div class="timepicker-canvas"></div>', '<div class="timepicker-dial timepicker-hours"></div>', '<div class="timepicker-dial timepicker-minutes timepicker-dial-out"></div>', '</div>', '<div class="timepicker-footer"></div>', '</div>', '</div>', '</div>'].join('');
+
+  M.Timepicker = Timepicker;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(Timepicker, 'timepicker', 'M_Timepicker');
+  }
+})(cash);
+;(function ($) {
+  'use strict';
+
+  var _defaults = {};
+
+  /**
+   * @class
+   *
+   */
+
+  var CharacterCounter = function (_Component17) {
+    _inherits(CharacterCounter, _Component17);
+
+    /**
+     * Construct CharacterCounter instance
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function CharacterCounter(el, options) {
+      _classCallCheck(this, CharacterCounter);
+
+      var _this61 = _possibleConstructorReturn(this, (CharacterCounter.__proto__ || Object.getPrototypeOf(CharacterCounter)).call(this, CharacterCounter, el, options));
+
+      _this61.el.M_CharacterCounter = _this61;
+
+      /**
+       * Options for the character counter
+       */
+      _this61.options = $.extend({}, CharacterCounter.defaults, options);
+
+      _this61.isInvalid = false;
+      _this61.isValidLength = false;
+      _this61._setupCounter();
+      _this61._setupEventHandlers();
+      return _this61;
+    }
+
+    _createClass(CharacterCounter, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        this._removeEventHandlers();
+        this.el.CharacterCounter = undefined;
+        this._removeCounter();
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        this._handleUpdateCounterBound = this.updateCounter.bind(this);
+
+        this.el.addEventListener('focus', this._handleUpdateCounterBound, true);
+        this.el.addEventListener('input', this._handleUpdateCounterBound, true);
+      }
+
+      /**
+       * Remove Event Handlers
+       */
+
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        this.el.removeEventListener('focus', this._handleUpdateCounterBound, true);
+        this.el.removeEventListener('input', this._handleUpdateCounterBound, true);
+      }
+
+      /**
+       * Setup counter element
+       */
+
+    }, {
+      key: "_setupCounter",
+      value: function _setupCounter() {
+        this.counterEl = document.createElement('span');
+        $(this.counterEl).addClass('character-counter').css({
+          float: 'right',
+          'font-size': '12px',
+          height: 1
+        });
+
+        this.$el.parent().append(this.counterEl);
+      }
+
+      /**
+       * Remove counter element
+       */
+
+    }, {
+      key: "_removeCounter",
+      value: function _removeCounter() {
+        $(this.counterEl).remove();
+      }
+
+      /**
+       * Update counter
+       */
+
+    }, {
+      key: "updateCounter",
+      value: function updateCounter() {
+        var maxLength = +this.$el.attr('data-length'),
+            actualLength = this.el.value.length;
+        this.isValidLength = actualLength <= maxLength;
+        var counterString = actualLength;
+
+        if (maxLength) {
+          counterString += '/' + maxLength;
+          this._validateInput();
+        }
+
+        $(this.counterEl).html(counterString);
+      }
+
+      /**
+       * Add validation classes
+       */
+
+    }, {
+      key: "_validateInput",
+      value: function _validateInput() {
+        if (this.isValidLength && this.isInvalid) {
+          this.isInvalid = false;
+          this.$el.removeClass('invalid');
+        } else if (!this.isValidLength && !this.isInvalid) {
+          this.isInvalid = true;
+          this.$el.removeClass('valid');
+          this.$el.addClass('invalid');
+        }
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(CharacterCounter.__proto__ || Object.getPrototypeOf(CharacterCounter), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_CharacterCounter;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return CharacterCounter;
+  }(Component);
+
+  M.CharacterCounter = CharacterCounter;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(CharacterCounter, 'characterCounter', 'M_CharacterCounter');
+  }
+})(cash);
+;(function ($) {
+  'use strict';
+
+  var _defaults = {
+    duration: 200, // ms
+    dist: -100, // zoom scale TODO: make this more intuitive as an option
+    shift: 0, // spacing for center image
+    padding: 0, // Padding between non center items
+    numVisible: 5, // Number of visible items in carousel
+    fullWidth: false, // Change to full width styles
+    indicators: false, // Toggle indicators
+    noWrap: false, // Don't wrap around and cycle through items.
+    onCycleTo: null // Callback for when a new slide is cycled to.
+  };
+
+  /**
+   * @class
+   *
+   */
+
+  var Carousel = function (_Component18) {
+    _inherits(Carousel, _Component18);
+
+    /**
+     * Construct Carousel instance
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function Carousel(el, options) {
+      _classCallCheck(this, Carousel);
+
+      var _this62 = _possibleConstructorReturn(this, (Carousel.__proto__ || Object.getPrototypeOf(Carousel)).call(this, Carousel, el, options));
+
+      _this62.el.M_Carousel = _this62;
+
+      /**
+       * Options for the carousel
+       * @member Carousel#options
+       * @prop {Number} duration
+       * @prop {Number} dist
+       * @prop {Number} shift
+       * @prop {Number} padding
+       * @prop {Number} numVisible
+       * @prop {Boolean} fullWidth
+       * @prop {Boolean} indicators
+       * @prop {Boolean} noWrap
+       * @prop {Function} onCycleTo
+       */
+      _this62.options = $.extend({}, Carousel.defaults, options);
+
+      // Setup
+      _this62.hasMultipleSlides = _this62.$el.find('.carousel-item').length > 1;
+      _this62.showIndicators = _this62.options.indicators && _this62.hasMultipleSlides;
+      _this62.noWrap = _this62.options.noWrap || !_this62.hasMultipleSlides;
+      _this62.pressed = false;
+      _this62.dragged = false;
+      _this62.offset = _this62.target = 0;
+      _this62.images = [];
+      _this62.itemWidth = _this62.$el.find('.carousel-item').first().innerWidth();
+      _this62.itemHeight = _this62.$el.find('.carousel-item').first().innerHeight();
+      _this62.dim = _this62.itemWidth * 2 + _this62.options.padding || 1; // Make sure dim is non zero for divisions.
+      _this62._autoScrollBound = _this62._autoScroll.bind(_this62);
+      _this62._trackBound = _this62._track.bind(_this62);
+
+      // Full Width carousel setup
+      if (_this62.options.fullWidth) {
+        _this62.options.dist = 0;
+        _this62._setCarouselHeight();
+
+        // Offset fixed items when indicators.
+        if (_this62.showIndicators) {
+          _this62.$el.find('.carousel-fixed-item').addClass('with-indicators');
+        }
+      }
+
+      // Iterate through slides
+      _this62.$indicators = $('<ul class="indicators"></ul>');
+      _this62.$el.find('.carousel-item').each(function (el, i) {
+        _this62.images.push(el);
+        if (_this62.showIndicators) {
+          var $indicator = $('<li class="indicator-item"></li>');
+
+          // Add active to first by default.
+          if (i === 0) {
+            $indicator[0].classList.add('active');
+          }
+
+          _this62.$indicators.append($indicator);
+        }
+      });
+      if (_this62.showIndicators) {
+        _this62.$el.append(_this62.$indicators);
+      }
+      _this62.count = _this62.images.length;
+
+      // Cap numVisible at count
+      _this62.options.numVisible = Math.min(_this62.count, _this62.options.numVisible);
+
+      // Setup cross browser string
+      _this62.xform = 'transform';
+      ['webkit', 'Moz', 'O', 'ms'].every(function (prefix) {
+        var e = prefix + 'Transform';
+        if (typeof document.body.style[e] !== 'undefined') {
+          _this62.xform = e;
+          return false;
+        }
+        return true;
+      });
+
+      _this62._setupEventHandlers();
+      _this62._scroll(_this62.offset);
+      return _this62;
+    }
+
+    _createClass(Carousel, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        this._removeEventHandlers();
+        this.el.M_Carousel = undefined;
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        var _this63 = this;
+
+        this._handleCarouselTapBound = this._handleCarouselTap.bind(this);
+        this._handleCarouselDragBound = this._handleCarouselDrag.bind(this);
+        this._handleCarouselReleaseBound = this._handleCarouselRelease.bind(this);
+        this._handleCarouselClickBound = this._handleCarouselClick.bind(this);
+
+        if (typeof window.ontouchstart !== 'undefined') {
+          this.el.addEventListener('touchstart', this._handleCarouselTapBound);
+          this.el.addEventListener('touchmove', this._handleCarouselDragBound);
+          this.el.addEventListener('touchend', this._handleCarouselReleaseBound);
+        }
+
+        this.el.addEventListener('mousedown', this._handleCarouselTapBound);
+        this.el.addEventListener('mousemove', this._handleCarouselDragBound);
+        this.el.addEventListener('mouseup', this._handleCarouselReleaseBound);
+        this.el.addEventListener('mouseleave', this._handleCarouselReleaseBound);
+        this.el.addEventListener('click', this._handleCarouselClickBound);
+
+        if (this.showIndicators && this.$indicators) {
+          this._handleIndicatorClickBound = this._handleIndicatorClick.bind(this);
+          this.$indicators.find('.indicator-item').each(function (el, i) {
+            el.addEventListener('click', _this63._handleIndicatorClickBound);
+          });
+        }
+
+        // Resize
+        var throttledResize = M.throttle(this._handleResize, 200);
+        this._handleThrottledResizeBound = throttledResize.bind(this);
+
+        window.addEventListener('resize', this._handleThrottledResizeBound);
+      }
+
+      /**
+       * Remove Event Handlers
+       */
+
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        var _this64 = this;
+
+        if (typeof window.ontouchstart !== 'undefined') {
+          this.el.removeEventListener('touchstart', this._handleCarouselTapBound);
+          this.el.removeEventListener('touchmove', this._handleCarouselDragBound);
+          this.el.removeEventListener('touchend', this._handleCarouselReleaseBound);
+        }
+        this.el.removeEventListener('mousedown', this._handleCarouselTapBound);
+        this.el.removeEventListener('mousemove', this._handleCarouselDragBound);
+        this.el.removeEventListener('mouseup', this._handleCarouselReleaseBound);
+        this.el.removeEventListener('mouseleave', this._handleCarouselReleaseBound);
+        this.el.removeEventListener('click', this._handleCarouselClickBound);
+
+        if (this.showIndicators && this.$indicators) {
+          this.$indicators.find('.indicator-item').each(function (el, i) {
+            el.removeEventListener('click', _this64._handleIndicatorClickBound);
+          });
+        }
+
+        window.removeEventListener('resize', this._handleThrottledResizeBound);
+      }
+
+      /**
+       * Handle Carousel Tap
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleCarouselTap",
+      value: function _handleCarouselTap(e) {
+        // Fixes firefox draggable image bug
+        if (e.type === 'mousedown' && $(e.target).is('img')) {
+          e.preventDefault();
+        }
+        this.pressed = true;
+        this.dragged = false;
+        this.verticalDragged = false;
+        this.reference = this._xpos(e);
+        this.referenceY = this._ypos(e);
+
+        this.velocity = this.amplitude = 0;
+        this.frame = this.offset;
+        this.timestamp = Date.now();
+        clearInterval(this.ticker);
+        this.ticker = setInterval(this._trackBound, 100);
+      }
+
+      /**
+       * Handle Carousel Drag
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleCarouselDrag",
+      value: function _handleCarouselDrag(e) {
+        var x = void 0,
+            y = void 0,
+            delta = void 0,
+            deltaY = void 0;
+        if (this.pressed) {
+          x = this._xpos(e);
+          y = this._ypos(e);
+          delta = this.reference - x;
+          deltaY = Math.abs(this.referenceY - y);
+          if (deltaY < 30 && !this.verticalDragged) {
+            // If vertical scrolling don't allow dragging.
+            if (delta > 2 || delta < -2) {
+              this.dragged = true;
+              this.reference = x;
+              this._scroll(this.offset + delta);
+            }
+          } else if (this.dragged) {
+            // If dragging don't allow vertical scroll.
+            e.preventDefault();
+            e.stopPropagation();
+            return false;
+          } else {
+            // Vertical scrolling.
+            this.verticalDragged = true;
+          }
+        }
+
+        if (this.dragged) {
+          // If dragging don't allow vertical scroll.
+          e.preventDefault();
+          e.stopPropagation();
+          return false;
+        }
+      }
+
+      /**
+       * Handle Carousel Release
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleCarouselRelease",
+      value: function _handleCarouselRelease(e) {
+        if (this.pressed) {
+          this.pressed = false;
+        } else {
+          return;
+        }
+
+        clearInterval(this.ticker);
+        this.target = this.offset;
+        if (this.velocity > 10 || this.velocity < -10) {
+          this.amplitude = 0.9 * this.velocity;
+          this.target = this.offset + this.amplitude;
+        }
+        this.target = Math.round(this.target / this.dim) * this.dim;
+
+        // No wrap of items.
+        if (this.noWrap) {
+          if (this.target >= this.dim * (this.count - 1)) {
+            this.target = this.dim * (this.count - 1);
+          } else if (this.target < 0) {
+            this.target = 0;
+          }
+        }
+        this.amplitude = this.target - this.offset;
+        this.timestamp = Date.now();
+        requestAnimationFrame(this._autoScrollBound);
+
+        if (this.dragged) {
+          e.preventDefault();
+          e.stopPropagation();
+        }
+        return false;
+      }
+
+      /**
+       * Handle Carousel CLick
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleCarouselClick",
+      value: function _handleCarouselClick(e) {
+        // Disable clicks if carousel was dragged.
+        if (this.dragged) {
+          e.preventDefault();
+          e.stopPropagation();
+          return false;
+        } else if (!this.options.fullWidth) {
+          var clickedIndex = $(e.target).closest('.carousel-item').index();
+          var diff = this._wrap(this.center) - clickedIndex;
+
+          // Disable clicks if carousel was shifted by click
+          if (diff !== 0) {
+            e.preventDefault();
+            e.stopPropagation();
+          }
+          this._cycleTo(clickedIndex);
+        }
+      }
+
+      /**
+       * Handle Indicator CLick
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleIndicatorClick",
+      value: function _handleIndicatorClick(e) {
+        e.stopPropagation();
+
+        var indicator = $(e.target).closest('.indicator-item');
+        if (indicator.length) {
+          this._cycleTo(indicator.index());
+        }
+      }
+
+      /**
+       * Handle Throttle Resize
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleResize",
+      value: function _handleResize(e) {
+        if (this.options.fullWidth) {
+          this.itemWidth = this.$el.find('.carousel-item').first().innerWidth();
+          this.imageHeight = this.$el.find('.carousel-item.active').height();
+          this.dim = this.itemWidth * 2 + this.options.padding;
+          this.offset = this.center * 2 * this.itemWidth;
+          this.target = this.offset;
+          this._setCarouselHeight(true);
+        } else {
+          this._scroll();
+        }
+      }
+
+      /**
+       * Set carousel height based on first slide
+       * @param {Booleam} imageOnly - true for image slides
+       */
+
+    }, {
+      key: "_setCarouselHeight",
+      value: function _setCarouselHeight(imageOnly) {
+        var _this65 = this;
+
+        var firstSlide = this.$el.find('.carousel-item.active').length ? this.$el.find('.carousel-item.active').first() : this.$el.find('.carousel-item').first();
+        var firstImage = firstSlide.find('img').first();
+        if (firstImage.length) {
+          if (firstImage[0].complete) {
+            // If image won't trigger the load event
+            var imageHeight = firstImage.height();
+            if (imageHeight > 0) {
+              this.$el.css('height', imageHeight + 'px');
+            } else {
+              // If image still has no height, use the natural dimensions to calculate
+              var naturalWidth = firstImage[0].naturalWidth;
+              var naturalHeight = firstImage[0].naturalHeight;
+              var adjustedHeight = this.$el.width() / naturalWidth * naturalHeight;
+              this.$el.css('height', adjustedHeight + 'px');
+            }
+          } else {
+            // Get height when image is loaded normally
+            firstImage.one('load', function (el, i) {
+              _this65.$el.css('height', el.offsetHeight + 'px');
+            });
+          }
+        } else if (!imageOnly) {
+          var slideHeight = firstSlide.height();
+          this.$el.css('height', slideHeight + 'px');
+        }
+      }
+
+      /**
+       * Get x position from event
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_xpos",
+      value: function _xpos(e) {
+        // touch event
+        if (e.targetTouches && e.targetTouches.length >= 1) {
+          return e.targetTouches[0].clientX;
+        }
+
+        // mouse event
+        return e.clientX;
+      }
+
+      /**
+       * Get y position from event
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_ypos",
+      value: function _ypos(e) {
+        // touch event
+        if (e.targetTouches && e.targetTouches.length >= 1) {
+          return e.targetTouches[0].clientY;
+        }
+
+        // mouse event
+        return e.clientY;
+      }
+
+      /**
+       * Wrap index
+       * @param {Number} x
+       */
+
+    }, {
+      key: "_wrap",
+      value: function _wrap(x) {
+        return x >= this.count ? x % this.count : x < 0 ? this._wrap(this.count + x % this.count) : x;
+      }
+
+      /**
+       * Tracks scrolling information
+       */
+
+    }, {
+      key: "_track",
+      value: function _track() {
+        var now = void 0,
+            elapsed = void 0,
+            delta = void 0,
+            v = void 0;
+
+        now = Date.now();
+        elapsed = now - this.timestamp;
+        this.timestamp = now;
+        delta = this.offset - this.frame;
+        this.frame = this.offset;
+
+        v = 1000 * delta / (1 + elapsed);
+        this.velocity = 0.8 * v + 0.2 * this.velocity;
+      }
+
+      /**
+       * Auto scrolls to nearest carousel item.
+       */
+
+    }, {
+      key: "_autoScroll",
+      value: function _autoScroll() {
+        var elapsed = void 0,
+            delta = void 0;
+
+        if (this.amplitude) {
+          elapsed = Date.now() - this.timestamp;
+          delta = this.amplitude * Math.exp(-elapsed / this.options.duration);
+          if (delta > 2 || delta < -2) {
+            this._scroll(this.target - delta);
+            requestAnimationFrame(this._autoScrollBound);
+          } else {
+            this._scroll(this.target);
+          }
+        }
+      }
+
+      /**
+       * Scroll to target
+       * @param {Number} x
+       */
+
+    }, {
+      key: "_scroll",
+      value: function _scroll(x) {
+        var _this66 = this;
+
+        // Track scrolling state
+        if (!this.$el.hasClass('scrolling')) {
+          this.el.classList.add('scrolling');
+        }
+        if (this.scrollingTimeout != null) {
+          window.clearTimeout(this.scrollingTimeout);
+        }
+        this.scrollingTimeout = window.setTimeout(function () {
+          _this66.$el.removeClass('scrolling');
+        }, this.options.duration);
+
+        // Start actual scroll
+        var i = void 0,
+            half = void 0,
+            delta = void 0,
+            dir = void 0,
+            tween = void 0,
+            el = void 0,
+            alignment = void 0,
+            zTranslation = void 0,
+            tweenedOpacity = void 0,
+            centerTweenedOpacity = void 0;
+        var lastCenter = this.center;
+        var numVisibleOffset = 1 / this.options.numVisible;
+
+        this.offset = typeof x === 'number' ? x : this.offset;
+        this.center = Math.floor((this.offset + this.dim / 2) / this.dim);
+        delta = this.offset - this.center * this.dim;
+        dir = delta < 0 ? 1 : -1;
+        tween = -dir * delta * 2 / this.dim;
+        half = this.count >> 1;
+
+        if (this.options.fullWidth) {
+          alignment = 'translateX(0)';
+          centerTweenedOpacity = 1;
+        } else {
+          alignment = 'translateX(' + (this.el.clientWidth - this.itemWidth) / 2 + 'px) ';
+          alignment += 'translateY(' + (this.el.clientHeight - this.itemHeight) / 2 + 'px)';
+          centerTweenedOpacity = 1 - numVisibleOffset * tween;
+        }
+
+        // Set indicator active
+        if (this.showIndicators) {
+          var diff = this.center % this.count;
+          var activeIndicator = this.$indicators.find('.indicator-item.active');
+          if (activeIndicator.index() !== diff) {
+            activeIndicator.removeClass('active');
+            this.$indicators.find('.indicator-item').eq(diff)[0].classList.add('active');
+          }
+        }
+
+        // center
+        // Don't show wrapped items.
+        if (!this.noWrap || this.center >= 0 && this.center < this.count) {
+          el = this.images[this._wrap(this.center)];
+
+          // Add active class to center item.
+          if (!$(el).hasClass('active')) {
+            this.$el.find('.carousel-item').removeClass('active');
+            el.classList.add('active');
+          }
+          var transformString = alignment + " translateX(" + -delta / 2 + "px) translateX(" + dir * this.options.shift * tween * i + "px) translateZ(" + this.options.dist * tween + "px)";
+          this._updateItemStyle(el, centerTweenedOpacity, 0, transformString);
+        }
+
+        for (i = 1; i <= half; ++i) {
+          // right side
+          if (this.options.fullWidth) {
+            zTranslation = this.options.dist;
+            tweenedOpacity = i === half && delta < 0 ? 1 - tween : 1;
+          } else {
+            zTranslation = this.options.dist * (i * 2 + tween * dir);
+            tweenedOpacity = 1 - numVisibleOffset * (i * 2 + tween * dir);
+          }
+          // Don't show wrapped items.
+          if (!this.noWrap || this.center + i < this.count) {
+            el = this.images[this._wrap(this.center + i)];
+            var _transformString = alignment + " translateX(" + (this.options.shift + (this.dim * i - delta) / 2) + "px) translateZ(" + zTranslation + "px)";
+            this._updateItemStyle(el, tweenedOpacity, -i, _transformString);
+          }
+
+          // left side
+          if (this.options.fullWidth) {
+            zTranslation = this.options.dist;
+            tweenedOpacity = i === half && delta > 0 ? 1 - tween : 1;
+          } else {
+            zTranslation = this.options.dist * (i * 2 - tween * dir);
+            tweenedOpacity = 1 - numVisibleOffset * (i * 2 - tween * dir);
+          }
+          // Don't show wrapped items.
+          if (!this.noWrap || this.center - i >= 0) {
+            el = this.images[this._wrap(this.center - i)];
+            var _transformString2 = alignment + " translateX(" + (-this.options.shift + (-this.dim * i - delta) / 2) + "px) translateZ(" + zTranslation + "px)";
+            this._updateItemStyle(el, tweenedOpacity, -i, _transformString2);
+          }
+        }
+
+        // center
+        // Don't show wrapped items.
+        if (!this.noWrap || this.center >= 0 && this.center < this.count) {
+          el = this.images[this._wrap(this.center)];
+          var _transformString3 = alignment + " translateX(" + -delta / 2 + "px) translateX(" + dir * this.options.shift * tween + "px) translateZ(" + this.options.dist * tween + "px)";
+          this._updateItemStyle(el, centerTweenedOpacity, 0, _transformString3);
+        }
+
+        // onCycleTo callback
+        var $currItem = this.$el.find('.carousel-item').eq(this._wrap(this.center));
+        if (lastCenter !== this.center && typeof this.options.onCycleTo === 'function') {
+          this.options.onCycleTo.call(this, $currItem[0], this.dragged);
+        }
+
+        // One time callback
+        if (typeof this.oneTimeCallback === 'function') {
+          this.oneTimeCallback.call(this, $currItem[0], this.dragged);
+          this.oneTimeCallback = null;
+        }
+      }
+
+      /**
+       * Cycle to target
+       * @param {Element} el
+       * @param {Number} opacity
+       * @param {Number} zIndex
+       * @param {String} transform
+       */
+
+    }, {
+      key: "_updateItemStyle",
+      value: function _updateItemStyle(el, opacity, zIndex, transform) {
+        el.style[this.xform] = transform;
+        el.style.zIndex = zIndex;
+        el.style.opacity = opacity;
+        el.style.visibility = 'visible';
+      }
+
+      /**
+       * Cycle to target
+       * @param {Number} n
+       * @param {Function} callback
+       */
+
+    }, {
+      key: "_cycleTo",
+      value: function _cycleTo(n, callback) {
+        var diff = this.center % this.count - n;
+
+        // Account for wraparound.
+        if (!this.noWrap) {
+          if (diff < 0) {
+            if (Math.abs(diff + this.count) < Math.abs(diff)) {
+              diff += this.count;
+            }
+          } else if (diff > 0) {
+            if (Math.abs(diff - this.count) < diff) {
+              diff -= this.count;
+            }
+          }
+        }
+
+        this.target = this.dim * Math.round(this.offset / this.dim);
+        // Next
+        if (diff < 0) {
+          this.target += this.dim * Math.abs(diff);
+
+          // Prev
+        } else if (diff > 0) {
+          this.target -= this.dim * diff;
+        }
+
+        // Set one time callback
+        if (typeof callback === 'function') {
+          this.oneTimeCallback = callback;
+        }
+
+        // Scroll
+        if (this.offset !== this.target) {
+          this.amplitude = this.target - this.offset;
+          this.timestamp = Date.now();
+          requestAnimationFrame(this._autoScrollBound);
+        }
+      }
+
+      /**
+       * Cycle to next item
+       * @param {Number} [n]
+       */
+
+    }, {
+      key: "next",
+      value: function next(n) {
+        if (n === undefined || isNaN(n)) {
+          n = 1;
+        }
+
+        var index = this.center + n;
+        if (index >= this.count || index < 0) {
+          if (this.noWrap) {
+            return;
+          }
+
+          index = this._wrap(index);
+        }
+        this._cycleTo(index);
+      }
+
+      /**
+       * Cycle to previous item
+       * @param {Number} [n]
+       */
+
+    }, {
+      key: "prev",
+      value: function prev(n) {
+        if (n === undefined || isNaN(n)) {
+          n = 1;
+        }
+
+        var index = this.center - n;
+        if (index >= this.count || index < 0) {
+          if (this.noWrap) {
+            return;
+          }
+
+          index = this._wrap(index);
+        }
+
+        this._cycleTo(index);
+      }
+
+      /**
+       * Cycle to nth item
+       * @param {Number} [n]
+       * @param {Function} callback
+       */
+
+    }, {
+      key: "set",
+      value: function set(n, callback) {
+        if (n === undefined || isNaN(n)) {
+          n = 0;
+        }
+
+        if (n > this.count || n < 0) {
+          if (this.noWrap) {
+            return;
+          }
+
+          n = this._wrap(n);
+        }
+
+        this._cycleTo(n, callback);
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(Carousel.__proto__ || Object.getPrototypeOf(Carousel), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Carousel;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Carousel;
+  }(Component);
+
+  M.Carousel = Carousel;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(Carousel, 'carousel', 'M_Carousel');
+  }
+})(cash);
+;(function ($) {
+  'use strict';
+
+  var _defaults = {
+    onOpen: undefined,
+    onClose: undefined
+  };
+
+  /**
+   * @class
+   *
+   */
+
+  var TapTarget = function (_Component19) {
+    _inherits(TapTarget, _Component19);
+
+    /**
+     * Construct TapTarget instance
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function TapTarget(el, options) {
+      _classCallCheck(this, TapTarget);
+
+      var _this67 = _possibleConstructorReturn(this, (TapTarget.__proto__ || Object.getPrototypeOf(TapTarget)).call(this, TapTarget, el, options));
+
+      _this67.el.M_TapTarget = _this67;
+
+      /**
+       * Options for the select
+       * @member TapTarget#options
+       * @prop {Function} onOpen - Callback function called when feature discovery is opened
+       * @prop {Function} onClose - Callback function called when feature discovery is closed
+       */
+      _this67.options = $.extend({}, TapTarget.defaults, options);
+
+      _this67.isOpen = false;
+
+      // setup
+      _this67.$origin = $('#' + _this67.$el.attr('data-target'));
+      _this67._setup();
+
+      _this67._calculatePositioning();
+      _this67._setupEventHandlers();
+      return _this67;
+    }
+
+    _createClass(TapTarget, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        this._removeEventHandlers();
+        this.el.TapTarget = undefined;
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        this._handleDocumentClickBound = this._handleDocumentClick.bind(this);
+        this._handleTargetClickBound = this._handleTargetClick.bind(this);
+        this._handleOriginClickBound = this._handleOriginClick.bind(this);
+
+        this.el.addEventListener('click', this._handleTargetClickBound);
+        this.originEl.addEventListener('click', this._handleOriginClickBound);
+
+        // Resize
+        var throttledResize = M.throttle(this._handleResize, 200);
+        this._handleThrottledResizeBound = throttledResize.bind(this);
+
+        window.addEventListener('resize', this._handleThrottledResizeBound);
+      }
+
+      /**
+       * Remove Event Handlers
+       */
+
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        this.el.removeEventListener('click', this._handleTargetClickBound);
+        this.originEl.removeEventListener('click', this._handleOriginClickBound);
+        window.removeEventListener('resize', this._handleThrottledResizeBound);
+      }
+
+      /**
+       * Handle Target Click
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleTargetClick",
+      value: function _handleTargetClick(e) {
+        this.open();
+      }
+
+      /**
+       * Handle Origin Click
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleOriginClick",
+      value: function _handleOriginClick(e) {
+        this.close();
+      }
+
+      /**
+       * Handle Resize
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleResize",
+      value: function _handleResize(e) {
+        this._calculatePositioning();
+      }
+
+      /**
+       * Handle Resize
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleDocumentClick",
+      value: function _handleDocumentClick(e) {
+        if (!$(e.target).closest('.tap-target-wrapper').length) {
+          this.close();
+          e.preventDefault();
+          e.stopPropagation();
+        }
+      }
+
+      /**
+       * Setup Tap Target
+       */
+
+    }, {
+      key: "_setup",
+      value: function _setup() {
+        // Creating tap target
+        this.wrapper = this.$el.parent()[0];
+        this.waveEl = $(this.wrapper).find('.tap-target-wave')[0];
+        this.originEl = $(this.wrapper).find('.tap-target-origin')[0];
+        this.contentEl = this.$el.find('.tap-target-content')[0];
+
+        // Creating wrapper
+        if (!$(this.wrapper).hasClass('.tap-target-wrapper')) {
+          this.wrapper = document.createElement('div');
+          this.wrapper.classList.add('tap-target-wrapper');
+          this.$el.before($(this.wrapper));
+          this.wrapper.append(this.el);
+        }
+
+        // Creating content
+        if (!this.contentEl) {
+          this.contentEl = document.createElement('div');
+          this.contentEl.classList.add('tap-target-content');
+          this.$el.append(this.contentEl);
+        }
+
+        // Creating foreground wave
+        if (!this.waveEl) {
+          this.waveEl = document.createElement('div');
+          this.waveEl.classList.add('tap-target-wave');
+
+          // Creating origin
+          if (!this.originEl) {
+            this.originEl = this.$origin.clone(true, true);
+            this.originEl.addClass('tap-target-origin');
+            this.originEl.removeAttr('id');
+            this.originEl.removeAttr('style');
+            this.originEl = this.originEl[0];
+            this.waveEl.append(this.originEl);
+          }
+
+          this.wrapper.append(this.waveEl);
+        }
+      }
+
+      /**
+       * Calculate positioning
+       */
+
+    }, {
+      key: "_calculatePositioning",
+      value: function _calculatePositioning() {
+        // Element or parent is fixed position?
+        var isFixed = this.$origin.css('position') === 'fixed';
+        if (!isFixed) {
+          var parents = this.$origin.parents();
+          for (var i = 0; i < parents.length; i++) {
+            isFixed = $(parents[i]).css('position') == 'fixed';
+            if (isFixed) {
+              break;
+            }
+          }
+        }
+
+        // Calculating origin
+        var originWidth = this.$origin.outerWidth();
+        var originHeight = this.$origin.outerHeight();
+        var originTop = isFixed ? this.$origin.offset().top - M.getDocumentScrollTop() : this.$origin.offset().top;
+        var originLeft = isFixed ? this.$origin.offset().left - M.getDocumentScrollLeft() : this.$origin.offset().left;
+
+        // Calculating screen
+        var windowWidth = window.innerWidth;
+        var windowHeight = window.innerHeight;
+        var centerX = windowWidth / 2;
+        var centerY = windowHeight / 2;
+        var isLeft = originLeft <= centerX;
+        var isRight = originLeft > centerX;
+        var isTop = originTop <= centerY;
+        var isBottom = originTop > centerY;
+        var isCenterX = originLeft >= windowWidth * 0.25 && originLeft <= windowWidth * 0.75;
+
+        // Calculating tap target
+        var tapTargetWidth = this.$el.outerWidth();
+        var tapTargetHeight = this.$el.outerHeight();
+        var tapTargetTop = originTop + originHeight / 2 - tapTargetHeight / 2;
+        var tapTargetLeft = originLeft + originWidth / 2 - tapTargetWidth / 2;
+        var tapTargetPosition = isFixed ? 'fixed' : 'absolute';
+
+        // Calculating content
+        var tapTargetTextWidth = isCenterX ? tapTargetWidth : tapTargetWidth / 2 + originWidth;
+        var tapTargetTextHeight = tapTargetHeight / 2;
+        var tapTargetTextTop = isTop ? tapTargetHeight / 2 : 0;
+        var tapTargetTextBottom = 0;
+        var tapTargetTextLeft = isLeft && !isCenterX ? tapTargetWidth / 2 - originWidth : 0;
+        var tapTargetTextRight = 0;
+        var tapTargetTextPadding = originWidth;
+        var tapTargetTextAlign = isBottom ? 'bottom' : 'top';
+
+        // Calculating wave
+        var tapTargetWaveWidth = originWidth > originHeight ? originWidth * 2 : originWidth * 2;
+        var tapTargetWaveHeight = tapTargetWaveWidth;
+        var tapTargetWaveTop = tapTargetHeight / 2 - tapTargetWaveHeight / 2;
+        var tapTargetWaveLeft = tapTargetWidth / 2 - tapTargetWaveWidth / 2;
+
+        // Setting tap target
+        var tapTargetWrapperCssObj = {};
+        tapTargetWrapperCssObj.top = isTop ? tapTargetTop + 'px' : '';
+        tapTargetWrapperCssObj.right = isRight ? windowWidth - tapTargetLeft - tapTargetWidth + 'px' : '';
+        tapTargetWrapperCssObj.bottom = isBottom ? windowHeight - tapTargetTop - tapTargetHeight + 'px' : '';
+        tapTargetWrapperCssObj.left = isLeft ? tapTargetLeft + 'px' : '';
+        tapTargetWrapperCssObj.position = tapTargetPosition;
+        $(this.wrapper).css(tapTargetWrapperCssObj);
+
+        // Setting content
+        $(this.contentEl).css({
+          width: tapTargetTextWidth + 'px',
+          height: tapTargetTextHeight + 'px',
+          top: tapTargetTextTop + 'px',
+          right: tapTargetTextRight + 'px',
+          bottom: tapTargetTextBottom + 'px',
+          left: tapTargetTextLeft + 'px',
+          padding: tapTargetTextPadding + 'px',
+          verticalAlign: tapTargetTextAlign
+        });
+
+        // Setting wave
+        $(this.waveEl).css({
+          top: tapTargetWaveTop + 'px',
+          left: tapTargetWaveLeft + 'px',
+          width: tapTargetWaveWidth + 'px',
+          height: tapTargetWaveHeight + 'px'
+        });
+      }
+
+      /**
+       * Open TapTarget
+       */
+
+    }, {
+      key: "open",
+      value: function open() {
+        if (this.isOpen) {
+          return;
+        }
+
+        // onOpen callback
+        if (typeof this.options.onOpen === 'function') {
+          this.options.onOpen.call(this, this.$origin[0]);
+        }
+
+        this.isOpen = true;
+        this.wrapper.classList.add('open');
+
+        document.body.addEventListener('click', this._handleDocumentClickBound, true);
+        document.body.addEventListener('touchend', this._handleDocumentClickBound);
+      }
+
+      /**
+       * Close Tap Target
+       */
+
+    }, {
+      key: "close",
+      value: function close() {
+        if (!this.isOpen) {
+          return;
+        }
+
+        // onClose callback
+        if (typeof this.options.onClose === 'function') {
+          this.options.onClose.call(this, this.$origin[0]);
+        }
+
+        this.isOpen = false;
+        this.wrapper.classList.remove('open');
+
+        document.body.removeEventListener('click', this._handleDocumentClickBound, true);
+        document.body.removeEventListener('touchend', this._handleDocumentClickBound);
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(TapTarget.__proto__ || Object.getPrototypeOf(TapTarget), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_TapTarget;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return TapTarget;
+  }(Component);
+
+  M.TapTarget = TapTarget;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(TapTarget, 'tapTarget', 'M_TapTarget');
+  }
+})(cash);
+;(function ($) {
+  'use strict';
+
+  var _defaults = {
+    classes: '',
+    dropdownOptions: {}
+  };
+
+  /**
+   * @class
+   *
+   */
+
+  var FormSelect = function (_Component20) {
+    _inherits(FormSelect, _Component20);
+
+    /**
+     * Construct FormSelect instance
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function FormSelect(el, options) {
+      _classCallCheck(this, FormSelect);
+
+      // Don't init if browser default version
+      var _this68 = _possibleConstructorReturn(this, (FormSelect.__proto__ || Object.getPrototypeOf(FormSelect)).call(this, FormSelect, el, options));
+
+      if (_this68.$el.hasClass('browser-default')) {
+        return _possibleConstructorReturn(_this68);
+      }
+
+      _this68.el.M_FormSelect = _this68;
+
+      /**
+       * Options for the select
+       * @member FormSelect#options
+       */
+      _this68.options = $.extend({}, FormSelect.defaults, options);
+
+      _this68.isMultiple = _this68.$el.prop('multiple');
+
+      // Setup
+      _this68.el.tabIndex = -1;
+      _this68._keysSelected = {};
+      _this68._valueDict = {}; // Maps key to original and generated option element.
+      _this68._setupDropdown();
+
+      _this68._setupEventHandlers();
+      return _this68;
+    }
+
+    _createClass(FormSelect, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        this._removeEventHandlers();
+        this._removeDropdown();
+        this.el.M_FormSelect = undefined;
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        var _this69 = this;
+
+        this._handleSelectChangeBound = this._handleSelectChange.bind(this);
+        this._handleOptionClickBound = this._handleOptionClick.bind(this);
+        this._handleInputClickBound = this._handleInputClick.bind(this);
+
+        $(this.dropdownOptions).find('li:not(.optgroup)').each(function (el) {
+          el.addEventListener('click', _this69._handleOptionClickBound);
+        });
+        this.el.addEventListener('change', this._handleSelectChangeBound);
+        this.input.addEventListener('click', this._handleInputClickBound);
+      }
+
+      /**
+       * Remove Event Handlers
+       */
+
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        var _this70 = this;
+
+        $(this.dropdownOptions).find('li:not(.optgroup)').each(function (el) {
+          el.removeEventListener('click', _this70._handleOptionClickBound);
+        });
+        this.el.removeEventListener('change', this._handleSelectChangeBound);
+        this.input.removeEventListener('click', this._handleInputClickBound);
+      }
+
+      /**
+       * Handle Select Change
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleSelectChange",
+      value: function _handleSelectChange(e) {
+        this._setValueToInput();
+      }
+
+      /**
+       * Handle Option Click
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleOptionClick",
+      value: function _handleOptionClick(e) {
+        e.preventDefault();
+        var option = $(e.target).closest('li')[0];
+        var key = option.id;
+        if (!$(option).hasClass('disabled') && !$(option).hasClass('optgroup') && key.length) {
+          var selected = true;
+
+          if (this.isMultiple) {
+            // Deselect placeholder option if still selected.
+            var placeholderOption = $(this.dropdownOptions).find('li.disabled.selected');
+            if (placeholderOption.length) {
+              placeholderOption.removeClass('selected');
+              placeholderOption.find('input[type="checkbox"]').prop('checked', false);
+              this._toggleEntryFromArray(placeholderOption[0].id);
+            }
+            selected = this._toggleEntryFromArray(key);
+          } else {
+            $(this.dropdownOptions).find('li').removeClass('selected');
+            $(option).toggleClass('selected', selected);
+          }
+
+          // Set selected on original select option
+          // Only trigger if selected state changed
+          var prevSelected = $(this._valueDict[key].el).prop('selected');
+          if (prevSelected !== selected) {
+            $(this._valueDict[key].el).prop('selected', selected);
+            this.$el.trigger('change');
+          }
+        }
+
+        e.stopPropagation();
+      }
+
+      /**
+       * Handle Input Click
+       */
+
+    }, {
+      key: "_handleInputClick",
+      value: function _handleInputClick() {
+        if (this.dropdown && this.dropdown.isOpen) {
+          this._setValueToInput();
+          this._setSelectedStates();
+        }
+      }
+
+      /**
+       * Setup dropdown
+       */
+
+    }, {
+      key: "_setupDropdown",
+      value: function _setupDropdown() {
+        var _this71 = this;
+
+        this.wrapper = document.createElement('div');
+        $(this.wrapper).addClass('select-wrapper ' + this.options.classes);
+        this.$el.before($(this.wrapper));
+        this.wrapper.appendChild(this.el);
+
+        if (this.el.disabled) {
+          this.wrapper.classList.add('disabled');
+        }
+
+        // Create dropdown
+        this.$selectOptions = this.$el.children('option, optgroup');
+        this.dropdownOptions = document.createElement('ul');
+        this.dropdownOptions.id = "select-options-" + M.guid();
+        $(this.dropdownOptions).addClass('dropdown-content select-dropdown ' + (this.isMultiple ? 'multiple-select-dropdown' : ''));
+
+        // Create dropdown structure.
+        if (this.$selectOptions.length) {
+          this.$selectOptions.each(function (el) {
+            if ($(el).is('option')) {
+              // Direct descendant option.
+              var optionEl = void 0;
+              if (_this71.isMultiple) {
+                optionEl = _this71._appendOptionWithIcon(_this71.$el, el, 'multiple');
+              } else {
+                optionEl = _this71._appendOptionWithIcon(_this71.$el, el);
+              }
+
+              _this71._addOptionToValueDict(el, optionEl);
+            } else if ($(el).is('optgroup')) {
+              // Optgroup.
+              var selectOptions = $(el).children('option');
+              $(_this71.dropdownOptions).append($('<li class="optgroup"><span>' + el.getAttribute('label') + '</span></li>')[0]);
+
+              selectOptions.each(function (el) {
+                var optionEl = _this71._appendOptionWithIcon(_this71.$el, el, 'optgroup-option');
+                _this71._addOptionToValueDict(el, optionEl);
+              });
+            }
+          });
+        }
+
+        this.$el.after(this.dropdownOptions);
+
+        // Add input dropdown
+        this.input = document.createElement('input');
+        $(this.input).addClass('select-dropdown dropdown-trigger');
+        this.input.setAttribute('type', 'text');
+        this.input.setAttribute('readonly', 'true');
+        this.input.setAttribute('data-target', this.dropdownOptions.id);
+        if (this.el.disabled) {
+          $(this.input).prop('disabled', 'true');
+        }
+
+        this.$el.before(this.input);
+        this._setValueToInput();
+
+        // Add caret
+        var dropdownIcon = $('<svg class="caret" height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="M7 10l5 5 5-5z"/><path d="M0 0h24v24H0z" fill="none"/></svg>');
+        this.$el.before(dropdownIcon[0]);
+
+        // Initialize dropdown
+        if (!this.el.disabled) {
+          var dropdownOptions = $.extend({}, this.options.dropdownOptions);
+
+          // Add callback for centering selected option when dropdown content is scrollable
+          dropdownOptions.onOpenEnd = function (el) {
+            var selectedOption = $(_this71.dropdownOptions).find('.selected').first();
+
+            if (selectedOption.length) {
+              // Focus selected option in dropdown
+              M.keyDown = true;
+              _this71.dropdown.focusedIndex = selectedOption.index();
+              _this71.dropdown._focusFocusedItem();
+              M.keyDown = false;
+
+              // Handle scrolling to selected option
+              if (_this71.dropdown.isScrollable) {
+                var scrollOffset = selectedOption[0].getBoundingClientRect().top - _this71.dropdownOptions.getBoundingClientRect().top; // scroll to selected option
+                scrollOffset -= _this71.dropdownOptions.clientHeight / 2; // center in dropdown
+                _this71.dropdownOptions.scrollTop = scrollOffset;
+              }
+            }
+          };
+
+          if (this.isMultiple) {
+            dropdownOptions.closeOnClick = false;
+          }
+          this.dropdown = M.Dropdown.init(this.input, dropdownOptions);
+        }
+
+        // Add initial selections
+        this._setSelectedStates();
+      }
+
+      /**
+       * Add option to value dict
+       * @param {Element} el  original option element
+       * @param {Element} optionEl  generated option element
+       */
+
+    }, {
+      key: "_addOptionToValueDict",
+      value: function _addOptionToValueDict(el, optionEl) {
+        var index = Object.keys(this._valueDict).length;
+        var key = this.dropdownOptions.id + index;
+        var obj = {};
+        optionEl.id = key;
+
+        obj.el = el;
+        obj.optionEl = optionEl;
+        this._valueDict[key] = obj;
+      }
+
+      /**
+       * Remove dropdown
+       */
+
+    }, {
+      key: "_removeDropdown",
+      value: function _removeDropdown() {
+        $(this.wrapper).find('.caret').remove();
+        $(this.input).remove();
+        $(this.dropdownOptions).remove();
+        $(this.wrapper).before(this.$el);
+        $(this.wrapper).remove();
+      }
+
+      /**
+       * Setup dropdown
+       * @param {Element} select  select element
+       * @param {Element} option  option element from select
+       * @param {String} type
+       * @return {Element}  option element added
+       */
+
+    }, {
+      key: "_appendOptionWithIcon",
+      value: function _appendOptionWithIcon(select, option, type) {
+        // Add disabled attr if disabled
+        var disabledClass = option.disabled ? 'disabled ' : '';
+        var optgroupClass = type === 'optgroup-option' ? 'optgroup-option ' : '';
+        var multipleCheckbox = this.isMultiple ? "<label><input type=\"checkbox\"" + disabledClass + "\"/><span>" + option.innerHTML + "</span></label>" : option.innerHTML;
+        var liEl = $('<li></li>');
+        var spanEl = $('<span></span>');
+        spanEl.html(multipleCheckbox);
+        liEl.addClass(disabledClass + " " + optgroupClass);
+        liEl.append(spanEl);
+
+        // add icons
+        var iconUrl = option.getAttribute('data-icon');
+        if (!!iconUrl) {
+          var imgEl = $("<img alt=\"\" src=\"" + iconUrl + "\">");
+          liEl.prepend(imgEl);
+        }
+
+        // Check for multiple type.
+        $(this.dropdownOptions).append(liEl[0]);
+        return liEl[0];
+      }
+
+      /**
+       * Toggle entry from option
+       * @param {String} key  Option key
+       * @return {Boolean}  if entry was added or removed
+       */
+
+    }, {
+      key: "_toggleEntryFromArray",
+      value: function _toggleEntryFromArray(key) {
+        var notAdded = !this._keysSelected.hasOwnProperty(key);
+        var $optionLi = $(this._valueDict[key].optionEl);
+
+        if (notAdded) {
+          this._keysSelected[key] = true;
+        } else {
+          delete this._keysSelected[key];
+        }
+
+        $optionLi.toggleClass('selected', notAdded);
+
+        // Set checkbox checked value
+        $optionLi.find('input[type="checkbox"]').prop('checked', notAdded);
+
+        // use notAdded instead of true (to detect if the option is selected or not)
+        $optionLi.prop('selected', notAdded);
+
+        return notAdded;
+      }
+
+      /**
+       * Set text value to input
+       */
+
+    }, {
+      key: "_setValueToInput",
+      value: function _setValueToInput() {
+        var values = [];
+        var options = this.$el.find('option');
+
+        options.each(function (el) {
+          if ($(el).prop('selected')) {
+            var text = $(el).text();
+            values.push(text);
+          }
+        });
+
+        if (!values.length) {
+          var firstDisabled = this.$el.find('option:disabled').eq(0);
+          if (firstDisabled.length && firstDisabled[0].value === '') {
+            values.push(firstDisabled.text());
+          }
+        }
+
+        this.input.value = values.join(', ');
+      }
+
+      /**
+       * Set selected state of dropdown to match actual select element
+       */
+
+    }, {
+      key: "_setSelectedStates",
+      value: function _setSelectedStates() {
+        this._keysSelected = {};
+
+        for (var key in this._valueDict) {
+          var option = this._valueDict[key];
+          var optionIsSelected = $(option.el).prop('selected');
+          $(option.optionEl).find('input[type="checkbox"]').prop('checked', optionIsSelected);
+          if (optionIsSelected) {
+            this._activateOption($(this.dropdownOptions), $(option.optionEl));
+            this._keysSelected[key] = true;
+          } else {
+            $(option.optionEl).removeClass('selected');
+          }
+        }
+      }
+
+      /**
+       * Make option as selected and scroll to selected position
+       * @param {jQuery} collection  Select options jQuery element
+       * @param {Element} newOption  element of the new option
+       */
+
+    }, {
+      key: "_activateOption",
+      value: function _activateOption(collection, newOption) {
+        if (newOption) {
+          if (!this.isMultiple) {
+            collection.find('li.selected').removeClass('selected');
+          }
+          var option = $(newOption);
+          option.addClass('selected');
+        }
+      }
+
+      /**
+       * Get Selected Values
+       * @return {Array}  Array of selected values
+       */
+
+    }, {
+      key: "getSelectedValues",
+      value: function getSelectedValues() {
+        var selectedValues = [];
+        for (var key in this._keysSelected) {
+          selectedValues.push(this._valueDict[key].el.value);
+        }
+        return selectedValues;
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(FormSelect.__proto__ || Object.getPrototypeOf(FormSelect), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_FormSelect;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return FormSelect;
+  }(Component);
+
+  M.FormSelect = FormSelect;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(FormSelect, 'formSelect', 'M_FormSelect');
+  }
+})(cash);
+;(function ($, anim) {
+  'use strict';
+
+  var _defaults = {};
+
+  /**
+   * @class
+   *
+   */
+
+  var Range = function (_Component21) {
+    _inherits(Range, _Component21);
+
+    /**
+     * Construct Range instance
+     * @constructor
+     * @param {Element} el
+     * @param {Object} options
+     */
+    function Range(el, options) {
+      _classCallCheck(this, Range);
+
+      var _this72 = _possibleConstructorReturn(this, (Range.__proto__ || Object.getPrototypeOf(Range)).call(this, Range, el, options));
+
+      _this72.el.M_Range = _this72;
+
+      /**
+       * Options for the range
+       * @member Range#options
+       */
+      _this72.options = $.extend({}, Range.defaults, options);
+
+      _this72._mousedown = false;
+
+      // Setup
+      _this72._setupThumb();
+
+      _this72._setupEventHandlers();
+      return _this72;
+    }
+
+    _createClass(Range, [{
+      key: "destroy",
+
+
+      /**
+       * Teardown component
+       */
+      value: function destroy() {
+        this._removeEventHandlers();
+        this._removeThumb();
+        this.el.M_Range = undefined;
+      }
+
+      /**
+       * Setup Event Handlers
+       */
+
+    }, {
+      key: "_setupEventHandlers",
+      value: function _setupEventHandlers() {
+        this._handleRangeChangeBound = this._handleRangeChange.bind(this);
+        this._handleRangeMousedownTouchstartBound = this._handleRangeMousedownTouchstart.bind(this);
+        this._handleRangeInputMousemoveTouchmoveBound = this._handleRangeInputMousemoveTouchmove.bind(this);
+        this._handleRangeMouseupTouchendBound = this._handleRangeMouseupTouchend.bind(this);
+        this._handleRangeBlurMouseoutTouchleaveBound = this._handleRangeBlurMouseoutTouchleave.bind(this);
+
+        this.el.addEventListener('change', this._handleRangeChangeBound);
+
+        this.el.addEventListener('mousedown', this._handleRangeMousedownTouchstartBound);
+        this.el.addEventListener('touchstart', this._handleRangeMousedownTouchstartBound);
+
+        this.el.addEventListener('input', this._handleRangeInputMousemoveTouchmoveBound);
+        this.el.addEventListener('mousemove', this._handleRangeInputMousemoveTouchmoveBound);
+        this.el.addEventListener('touchmove', this._handleRangeInputMousemoveTouchmoveBound);
+
+        this.el.addEventListener('mouseup', this._handleRangeMouseupTouchendBound);
+        this.el.addEventListener('touchend', this._handleRangeMouseupTouchendBound);
+
+        this.el.addEventListener('blur', this._handleRangeBlurMouseoutTouchleaveBound);
+        this.el.addEventListener('mouseout', this._handleRangeBlurMouseoutTouchleaveBound);
+        this.el.addEventListener('touchleave', this._handleRangeBlurMouseoutTouchleaveBound);
+      }
+
+      /**
+       * Remove Event Handlers
+       */
+
+    }, {
+      key: "_removeEventHandlers",
+      value: function _removeEventHandlers() {
+        this.el.removeEventListener('change', this._handleRangeChangeBound);
+
+        this.el.removeEventListener('mousedown', this._handleRangeMousedownTouchstartBound);
+        this.el.removeEventListener('touchstart', this._handleRangeMousedownTouchstartBound);
+
+        this.el.removeEventListener('input', this._handleRangeInputMousemoveTouchmoveBound);
+        this.el.removeEventListener('mousemove', this._handleRangeInputMousemoveTouchmoveBound);
+        this.el.removeEventListener('touchmove', this._handleRangeInputMousemoveTouchmoveBound);
+
+        this.el.removeEventListener('mouseup', this._handleRangeMouseupTouchendBound);
+        this.el.removeEventListener('touchend', this._handleRangeMouseupTouchendBound);
+
+        this.el.removeEventListener('blur', this._handleRangeBlurMouseoutTouchleaveBound);
+        this.el.removeEventListener('mouseout', this._handleRangeBlurMouseoutTouchleaveBound);
+        this.el.removeEventListener('touchleave', this._handleRangeBlurMouseoutTouchleaveBound);
+      }
+
+      /**
+       * Handle Range Change
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleRangeChange",
+      value: function _handleRangeChange() {
+        $(this.value).html(this.$el.val());
+
+        if (!$(this.thumb).hasClass('active')) {
+          this._showRangeBubble();
+        }
+
+        var offsetLeft = this._calcRangeOffset();
+        $(this.thumb).addClass('active').css('left', offsetLeft + 'px');
+      }
+
+      /**
+       * Handle Range Mousedown and Touchstart
+       * @param {Event} e
+       */
+
+    }, {
+      key: "_handleRangeMousedownTouchstart",
+      value: function _handleRangeMousedownTouchstart(e) {
+        // Set indicator value
+        $(this.value).html(this.$el.val());
+
+        this._mousedown = true;
+        this.$el.addClass('active');
+
+        if (!$(this.thumb).hasClass('active')) {
+          this._showRangeBubble();
+        }
+
+        if (e.type !== 'input') {
+          var offsetLeft = this._calcRangeOffset();
+          $(this.thumb).addClass('active').css('left', offsetLeft + 'px');
+        }
+      }
+
+      /**
+       * Handle Range Input, Mousemove and Touchmove
+       */
+
+    }, {
+      key: "_handleRangeInputMousemoveTouchmove",
+      value: function _handleRangeInputMousemoveTouchmove() {
+        if (this._mousedown) {
+          if (!$(this.thumb).hasClass('active')) {
+            this._showRangeBubble();
+          }
+
+          var offsetLeft = this._calcRangeOffset();
+          $(this.thumb).addClass('active').css('left', offsetLeft + 'px');
+          $(this.value).html(this.$el.val());
+        }
+      }
+
+      /**
+       * Handle Range Mouseup and Touchend
+       */
+
+    }, {
+      key: "_handleRangeMouseupTouchend",
+      value: function _handleRangeMouseupTouchend() {
+        this._mousedown = false;
+        this.$el.removeClass('active');
+      }
+
+      /**
+       * Handle Range Blur, Mouseout and Touchleave
+       */
+
+    }, {
+      key: "_handleRangeBlurMouseoutTouchleave",
+      value: function _handleRangeBlurMouseoutTouchleave() {
+        if (!this._mousedown) {
+          var paddingLeft = parseInt(this.$el.css('padding-left'));
+          var marginLeft = 7 + paddingLeft + 'px';
+
+          if ($(this.thumb).hasClass('active')) {
+            anim.remove(this.thumb);
+            anim({
+              targets: this.thumb,
+              height: 0,
+              width: 0,
+              top: 10,
+              easing: 'easeOutQuad',
+              marginLeft: marginLeft,
+              duration: 100
+            });
+          }
+          $(this.thumb).removeClass('active');
+        }
+      }
+
+      /**
+       * Setup dropdown
+       */
+
+    }, {
+      key: "_setupThumb",
+      value: function _setupThumb() {
+        this.thumb = document.createElement('span');
+        this.value = document.createElement('span');
+        $(this.thumb).addClass('thumb');
+        $(this.value).addClass('value');
+        $(this.thumb).append(this.value);
+        this.$el.after(this.thumb);
+      }
+
+      /**
+       * Remove dropdown
+       */
+
+    }, {
+      key: "_removeThumb",
+      value: function _removeThumb() {
+        $(this.thumb).remove();
+      }
+
+      /**
+       * morph thumb into bubble
+       */
+
+    }, {
+      key: "_showRangeBubble",
+      value: function _showRangeBubble() {
+        var paddingLeft = parseInt($(this.thumb).parent().css('padding-left'));
+        var marginLeft = -7 + paddingLeft + 'px'; // TODO: fix magic number?
+        anim.remove(this.thumb);
+        anim({
+          targets: this.thumb,
+          height: 30,
+          width: 30,
+          top: -30,
+          marginLeft: marginLeft,
+          duration: 300,
+          easing: 'easeOutQuint'
+        });
+      }
+
+      /**
+       * Calculate the offset of the thumb
+       * @return {Number}  offset in pixels
+       */
+
+    }, {
+      key: "_calcRangeOffset",
+      value: function _calcRangeOffset() {
+        var width = this.$el.width() - 15;
+        var max = parseFloat(this.$el.attr('max')) || 100; // Range default max
+        var min = parseFloat(this.$el.attr('min')) || 0; // Range default min
+        var percent = (parseFloat(this.$el.val()) - min) / (max - min);
+        return percent * width;
+      }
+    }], [{
+      key: "init",
+      value: function init(els, options) {
+        return _get(Range.__proto__ || Object.getPrototypeOf(Range), "init", this).call(this, this, els, options);
+      }
+
+      /**
+       * Get Instance
+       */
+
+    }, {
+      key: "getInstance",
+      value: function getInstance(el) {
+        var domElem = !!el.jquery ? el[0] : el;
+        return domElem.M_Range;
+      }
+    }, {
+      key: "defaults",
+      get: function () {
+        return _defaults;
+      }
+    }]);
+
+    return Range;
+  }(Component);
+
+  M.Range = Range;
+
+  if (M.jQueryLoaded) {
+    M.initializeJqueryWrapper(Range, 'range', 'M_Range');
+  }
+
+  Range.init($('input[type=range]'));
+})(cash, M.anime);
diff --git a/script.js b/js/script.js
similarity index 81%
rename from script.js
rename to js/script.js
index 497a48f..ef3d446 100644
--- a/script.js
+++ b/js/script.js
@@ -1,5 +1,5 @@
 function updateHost(input) {
-    input.style.backgroundImage = 'url(wait.gif)'
+    input.style.backgroundImage = 'url(img/wait.gif)'
     input.style.fontStyle = "italic"
     fetch(new Request("updateHost.php", {
         method:"POST",
@@ -10,7 +10,7 @@ function updateHost(input) {
             input.style.backgroundImage = ''
             input.style.fontStyle = ""
         } else {
-            input.style.backgroundImage = 'url(nok.png)'
+            input.style.backgroundImage = 'url(img/nok.png)'
         }
     })
 }
diff --git a/siteNetworks.php b/siteNetworks.php
index f90acd3..afe4324 100644
--- a/siteNetworks.php
+++ b/siteNetworks.php
@@ -1,7 +1,6 @@
 <?php
 $MAX_LINES = 2500;
 
-include "connect.php";
 $siteName = $_GET["site"];
 // Check if site is known
 $site = $db->prepare('SELECT id from Sites WHERE Name=:siteName');
@@ -13,17 +12,19 @@ if (!$siteId) {
 }
 ?>
 
-<html>
-    <head>
-        <title>TablIP - <?=$siteName?></title>
-        <link rel="stylesheet" href="style.css"/>
-        <script src="script.js"></script>
-    </head>
-    <body>
         <header>
-            <h1>TablIP</h1>
-            <h2><?=$siteName?></h2>
+            <nav>
+                <div class="nav-wrapper navbar-fixed cyan lighten-2">
+                    <a href="." class="brand-logo center">TablIP</a>
+                    <div>
+                        <a href="." class="breadcrumb">Sites</a>
+                        <a href=".?Site=<?=$siteName?>" class="breadcrumb"><?=$siteName?></a>
+                    </div>
+                </div>
+            </nav>
         </header>
+        <div class="container">
+            <h1><?=$siteName?></h1>
 
 <?php
 $networks = $db->query("SELECT * FROM `Networks` WHERE `SiteId` = $siteId");
@@ -33,71 +34,81 @@ while ($network = $networks->fetch())
     $networkAddress = (int) $network["Address"];
     $networkMask = (int) $network["Mask"];
 ?>
-        <table style="width:100%">
-            <caption><?=$network['Name']." : ".long2ip($networkAddress)." / ".long2ip($networkMask)?><caption>
-            <thead>
-                <tr>
-                    <th>Adresse IP</th>
-                    <th>Nom d'hôte</th>
-                    <th>FQDN</th>
-                    <th>Adresse MAC</th>
-                    <th>Commentaires</th>
-                <tr>
-                    <td><em><?= long2ip($networkAddress)?></em></td>
-                    <td colspan="4"><em>Adresse réseau</em></td>
-                </tr>
-                </tr>
-            </thead>
-            <tbody>
+            <div class="card">
+                <div class="card-content">
+                    <span class="card-title"><?=$network['Name']." @ ".long2ip($networkAddress)." / ".long2ip($networkMask)?></span>
+                    <table class="striped responsive-table">
+                        <thead>
+                            <tr>
+                                <th>Adresse IP</th>
+                                <th>Nom d'hôte</th>
+                                <th>FQDN</th>
+                                <th>Adresse MAC</th>
+                                <th>Commentaires</th>
+                            <tr>
+                                <td><em><?= long2ip($networkAddress)?></em></td>
+                                <td colspan="4"><em>Adresse réseau</em></td>
+                            </tr>
+                            </tr>
+                        </thead>
+                        <tbody>
 <?php
     for ($ip = $networkAddress + 1; ($ip+1 & $networkMask) == $networkAddress && $ip < $networkAddress + $MAX_LINES; $ip++ ) {
         $hosts = $db->query("SELECT * from `Hosts` WHERE IPAddress=$ip AND NetworkId=$networkId");
         $host = $hosts->fetch();
 ?>
-                <tr>
-                    <form>
-                        <input type="hidden" name="Ip" value=<?=$ip?>/>
-                        <input type="hidden" name="NetworkId" value=<?=$networkId?>/>
-                        <td><?=long2ip($ip)?></td>
-                        <td><input type="text" onchange="updateHost(this)" name='Hostname' value="<?=$host["Hostname"]?>"/></td>
-                        <td><input type="text" onchange="updateHost(this)" name='FQDN' value="<?=$host["FQDN"]?>"/></td>
-                        <td><input type="text" onchange="updateHost(this)" name='MacAddress' value="<?=$host["MacAddress"]?>"/></td>
-                        <td><input type="text" onchange="updateHost(this)" name='Comments' value="<?=$host["Comments"]?>"/></td>
-                    </form>
-                </tr>
+                            <tr>
+                                <form>
+                                    <input type="hidden" name="Ip" value=<?=$ip?>/>
+                                    <input type="hidden" name="NetworkId" value=<?=$networkId?>/>
+                                    <td><?=long2ip($ip)?></td>
+                                    <td class="td-input"><input type="text" onchange="updateHost(this)" name='Hostname' value="<?=$host["Hostname"]?>"/></td>
+                                    <td class="td-input"><input type="text" onchange="updateHost(this)" name='FQDN' value="<?=$host["FQDN"]?>"/></td>
+                                    <td class="td-input"><input type="text" onchange="updateHost(this)" name='MacAddress' value="<?=$host["MacAddress"]?>"/></td>
+                                    <td class="td-input"><input type="text" onchange="updateHost(this)" name='Comments' value="<?=$host["Comments"]?>"/></td>
+                                </form>
+                            </tr>
 <?php
     }
 ?>                  
-                </tbody>
-                <tfoot>
-                    <tr>
-                        <td><em><?= long2ip($ip)?></em></td>
-                        <td colspan="4"><em>Adresse de diffusion</em></td>
-                    </tr>
-                </tfoot>
-        </table>
+                        </tbody>
+                        <tfoot>
+                            <tr>
+                                <td><em><?= long2ip($ip)?></em></td>
+                                <td colspan="4"><em>Adresse de diffusion</em></td>
+                            </tr>
+                        </tfoot>
+                    </table>
+                </div>
+            </div>
 <?php
 }
 $networks->closeCursor();
 ?>
 
-        <form name="addNetwork" id="addNetwork" action="addNetwork.php" method="post">
-            <fieldset class="add">
-                <legend>Ajouter un réseau</legend>
-                <label for="nameInput">Nom</label>
-                <input type="text" id="nameInput" name="name" required/>
-                <label for="gatewayInput">Passerelle</label>
-                <input type="text" id="gatewayInput" name="gateway" pattern="^(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$"/>
-                <label for="maskInput">Masque</label>
-                <input type="text" id="maskInput" name="mask" pattern="^((0|128|192|224|240|248|252|255)\.0\.0.0|255\.(0|128|192|224|240|248|252|255)\.0\.0|255\.255\.(0|128|192|224|240|248|252|255)\.0|255\.255\.255\.(0|128|192|224|240|248|252|255))$"'/>
-                <input type="hidden" name="siteId" value="<?=$siteId?>"/>
-                <input type="hidden" name="siteName" value="<?=$siteName?>"/>
-                <button id="addButton" type="submit">Ajouter</button>
-            </fieldset>
-        </form>
+            <div class="card teal lighten-5">
+                <div class="card-content">
+                    <span class="card-title">Nouveau réseau</span>
+                    <form name="addNetwork" id="addNetwork" action="addNetwork.php" method="post">
+                        <input type="hidden" name="siteId" value="<?=$siteId?>"/>
+                        <input type="hidden" name="siteName" value="<?=$siteName?>"/>
+                        <div class="input-field">
+                            <label for="nameInput">Nom</label>
+                            <input type="text" class="validate" id="nameInput" name="name" placeholder="LAN" required/>
+                        </div>
+                        <div class="input-field">
+                            <label for="gatewayInput">Passerelle</label>
+                            <input type="text" class="validate" id="gatewayInput" name="gateway" placeholder="192.168.0.1" pattern="^(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$"/>
+                        </div>
+                        <div class="input-field">
+                            <label for="maskInput">Masque</label>
+                            <input type="text" class="validate" id="maskInput" name="mask" placeholder="255.255.255.0" pattern="^((0|128|192|224|240|248|252|255)\.0\.0.0|255\.(0|128|192|224|240|248|252|255)\.0\.0|255\.255\.(0|128|192|224|240|248|252|255)\.0|255\.255\.255\.(0|128|192|224|240|248|252|255))$"'/>
+                        </div>
+                        <button type="submit" class="btn-floating halfway-fab waves-effect waves-light teal"><i class="material-icons">add</i></button>
+                    </form>
+                </div>
+            </div>
+        </div>
+
+
 
-        <footer>
-            <a href=".">Accueil</a>
-        </footer>
-    </body>
-</html>
\ No newline at end of file
diff --git a/sitesList.php b/sitesList.php
index ca3dcd3..762110b 100644
--- a/sitesList.php
+++ b/sitesList.php
@@ -1,32 +1,38 @@
-<html>
-    <head>
-        <title>TablIP</title>
-        <link rel="stylesheet" href="style.css"/>
-    </head>
-    <body>
         <header>
-            <h1>TablIP</h1>
+            <nav>
+                <div class="nav-wrapper navbar-fixed teal lighten-2">
+                    <a href="." class="brand-logo center">TablIP</a>
+                    <div>
+                        <a href="." class="breadcrumb">Sites</a>
+                    </div>
+                </div>
+            </nav>
         </header>
-        <ul>
+        <div class="container">
+            <h1>Sites</h1>
+            <div class="collection">
 
 <?php
 include "connect.php";
-$sites = $db->query('SELECT Name FROM Site ORDER BY Name');
+$sites = $db->query('SELECT Name FROM Sites ORDER BY Name');
 while ($site = $sites->fetch())
 {
-    echo "        <li><a href='.?site=${site['Name']}'>${site['Name']}</a></li>\n";
+    echo "            <a href='.?site=${site['Name']}' class='collection-item'>${site['Name']}</a>\n";
 }
 $sites->closeCursor();
 ?>
 
-        </ul>
-        <form name="addSite" id="addSite" action="addSite.php" method="post">
-            <fieldset class="add">
-                <legend>Ajouter un site</legend>
-                <label for="siteName">Nom</label>
-                <input type="text" id="siteName" name="siteName" required/>
-                <button type="submit">Ajouter</button>
-            </fieldset>
-        </form>
-    </body>
-</html>
\ No newline at end of file
+            </div>
+            <div class="card teal lighten-5">
+                <div class="card-content">
+                    <span class="card-title">Nouveau site</span>
+                    <form name="addSite" id="addSite" action="addSite.php" method="post">
+                        <div class="input-field">
+                            <label for="siteName">Nom</label>
+                            <input type="text" class="validate" id="siteName" name="siteName" placeholder="Site" required/>
+                        </div>
+                        <button type="submit" class="btn-floating halfway-fab waves-effect waves-light teal"><i class="material-icons">add</i></button>
+                    </form>
+                </div>
+            </div>
+        </div>
\ No newline at end of file
diff --git a/style.css b/style.css
deleted file mode 100644
index 096487f..0000000
--- a/style.css
+++ /dev/null
@@ -1,45 +0,0 @@
-body {
-    margin: auto 1em;
-}
-
-header {
-    text-align: center;
-}
-
-li {
-    list-style: none;
-}
-
-table {
-    border-collapse: collapse;
-}
-
-th, td {
-    border: solid 1px;
-}
-
-td {
-    padding: 0;
-}
-
-td input {
-    border: 0;
-    background-repeat: no-repeat;
-    background-position: right center;
-    width: 100%;
-}
-
-.add {
-    display: grid;
-    grid-template-columns: 1fr 2fr;
-    grid-gap: 1em;
-}
-.add button {
-    width: 100%;
-    margin: auto;
-    grid-column: 1/3;
-}
-
-footer {
-    text-align: center;
-}
\ No newline at end of file